React

1476 날짜 계산

문제

준규가 사는 나라는 우리가 사용하는 연도와 다른 방식을 이용한다. 준규가 사는 나라에서는 수 3개를 이용해서 연도를 나타낸다. 각각의 수는 지구, 태양, 그리고 달을 나타낸다.
지구를 나타내는 수를 E, 태양을 나타내는 수를 S, 달을 나타내는 수를 M이라고 했을 때, 이 세 수는 서로 다른 범위를 가진다. (1 ≤ E ≤ 15, 1 ≤ S ≤ 28, 1 ≤ M ≤ 19)
우리가 알고있는 1년은 준규가 살고있는 나라에서는 1 1 1로 나타낼 수 있다. 1년이 지날 때마다, 세 수는 모두 1씩 증가한다. 만약, 어떤 수가 범위를 넘어가는 경우에는 1이 된다.
예를 들어, 15년은 15 15 15로 나타낼 수 있다. 하지만, 1년이 지나서 16년이 되면 16 16 16이 아니라 1 16 16이 된다. 이유는 1 ≤ E ≤ 15 라서 범위를 넘어가기 때문이다.
E, S, M이 주어졌고, 1년이 준규가 사는 나라에서 1 1 1일때, 준규가 사는 나라에서 E S M이 우리가 알고 있는 연도로 몇 년인지 구하는 프로그램을 작성하시오.

입력

첫째 줄에 세 수 E, S, M이 주어진다. 문제에 나와있는 범위를 지키는 입력만 주어진다.

출력

첫째 줄에 E S M으로 표시되는 가장 빠른 연도를 출력한다. 1 1 1은 항상 1이기 때문에, 정답이 음수가 나오는 경우는 없다.

예제 입력 1

1 16 16
Plain Text
복사

예제 출력 1

16
Plain Text
복사

예제 입력 2

1 1 1
Plain Text
복사

예제 출력 2

1
Plain Text
복사

예제 입력 3

1 2 3
Plain Text
복사

예제 출력 3

5266
Plain Text
복사

예제 입력 4

15 28 19
Plain Text
복사

예제 출력 4

7980
Plain Text
복사

My solution

E, S, M을 동등하게 증가시키다가 범위를 초과할 때 1로 초기화해주는 반복문을 작성하면 된다.
const [E, S, M] = i.toString().trim().split(' ').map(Number); // 처음부터 1 16 16 이 나올 때까지 탐색한다. year를 누적한다. let year = 0; for (let i = 1, j = 1, k = 1; i <= 16, j <= 29, k <= 20; i++, j++, k++) { if (i === 16) i = 1; if (j === 29) j = 1; if (k === 20) k = 1; year++; if (i === E && j === S && k === M) return year; }
JavaScript
복사
변수 4개를 두면 메모리 초과가 난다.
따라서 year 변수 하나로 E, S, M 비교를 모두 해야 한다.
이를 위해서는 나머지 연산을 이용해야 한다. 범위를 초과하는 값이면 나머지가 1부터 나타나게 된다.
ex) x % 15 = 16 % 15 = 1
x % 28 = 16 % 28 = 16
x % 28 = 16 % 28 = 16
이 세가지 조건이 모두 만족되면 그때의 year값을 출력한다.
year과 E, S, M을 각각 뺀 값의
// year를 1로 초기화하지 않고 E, S, M과 비교하기 위해 E, S, M 범위를 0 ~ N으로 변경 // E : 0 ~ 15, S : 0 ~ 28, M : 0 ~ 19 if ( (year - E) % 15 === 0 && (year - S) % 28 === 0 && (year - M) % 19 === 0 ) { break; } // if(i % 15 == e && i % 28 == s && i % 19 == m)도 무관
JavaScript
복사
Node.js는 메모리 초과가 난다.

Code

const solution = function (i) { const [E, S, M] = i.toString().trim().split(' ').map(Number); let year = 0; while (++year) { if ( (year - E) % 15 === 0 && (year - S) % 28 === 0 && (year - M) % 19 === 0 ) { break; } } console.log(year); return year; }; describe('날짜계산', () => { it('TC1', () => { expect(solution(`1 16 16`)).toStrictEqual(16); }); it('TC2', () => { expect(solution(`1 1 1`)).toStrictEqual(1); }); it('TC3', () => { expect(solution(`1 2 3`)).toStrictEqual(5266); }); it('TC4', () => { expect(solution(`15 28 19`)).toStrictEqual(7980); }); });
JavaScript
복사