알고리즘/BOJ
[BOJ] 2292 - 벌집
쭁쭁이
2018. 4. 15. 00:53
문제
육각형 벌집의 각 방에 들어가기 위해 몇 개의 방을 거쳐야 하는지 구하는 문제.
난이도
난이도 下, 소요시간 10분
풀이 과정
정답률 47%짜리 문제에 실패라 떠있길래 뭐지..? 하고 눌러봤는데
예전에 내가 풀었던 문제였다.
채점 기록을 보니까 6개월 전에 3번 제출했는데 3번 다 틀렸다ㅋㅋㅋㅋ
문제를 보니까 기억이 났다.
그때의 나는 이걸 틀린 수준이었던가...
벌집의 규칙은 이렇다.
가운데 1개
가장자리 6개
그 가장자리 12개
그그 가장자리 18개
...
6의 배수로 증가함을 알 수 있다.
따라서 1은 1개의 방, 2~7은 2개의 방, 8~19는 3개의 방, ...
이고 이는 몇 번째 가장자리에 속하는가?를 구하는 문제와 같다.
따라서 N이 주어지면 N보다 작거나 같은 범위 내에서 1+6+12+18+... 이 어디까지 들어가느냐는 문제이다.
즉,
인 n을 구하면 된다.
따라서 다음과 같이 코드를 작성하면 된다.
#include <iostream> using namespace std; int main(void) { int N = 0, sum = 1, n = 0; cin >> N; if (N == 1) cout << 1 << endl; else { while (sum < N) { sum += 6 * n; n++; } cout << n << endl; } return 0; }