티스토리 뷰

https://www.acmicpc.net/problem/2632

 

2632번: 피자판매

첫 번째 줄에는 손님이 구매하고자 하는 피자크기를 나타내는 2,000,000 이하의 자연수가 주어진다. 두 번째 줄에는 A, B 피자의 피자조각의 개수를 나타내 는 정수 m, n 이 차례로 주어진다 (3 ≤ m, n

www.acmicpc.net

const fs = require('fs');
const input = fs.readFileSync("./dev/stdin").toString().trim().split("\n");
const target = +input.shift()
const [a, b] = input.shift().split(' ').map(Number)
let pizzaA = [];
let pizzaB = [];
let answer = 0;
let possibleA = new Array(target + 1).fill(0)
possibleA[0] = 1;
let possibleB = new Array(target + 1).fill(0)
possibleB[0] = 1;


for (let i = 0; i < a; i++) {
  pizzaA.push(+input.shift())
}

for (let i = 0; i < b; i++) {
  pizzaB.push(+input.shift())
}


for (let i = 0; i < a; i++) {
  let sum = 0;
  for (let j = i; j < i + a - 1; j++) {
    sum += pizzaA[j % a];
    if (sum <= target) {
      possibleA[sum]++;
    } else {
      break;
    }
  }
}

const sumA = pizzaA.reduce((r, v) => r + v, 0)
if (sumA <= target) {
  possibleA[sumA]++;
}


for (let i = 0; i < b; i++) {
  let sum = 0;
  for (let j = i; j < i + b - 1; j++) {
    sum += pizzaB[j % b];
    if (sum <= target) {
      possibleB[sum]++;
    } else {
      break;
    }
  }
}

const sumB = pizzaB.reduce((r, v) => r + v, 0)
if (sumB <= target) {
  possibleB[sumB]++;
}

for (let i = 0; i <= target; i++) {
  answer += (possibleA[i] * possibleB[target - i])
}

// console.log(possibleA)
// console.log(possibleB)

console.log(answer)
728x90
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/02   »
1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28
글 보관함