티스토리 뷰

알고리즘/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;
}


'알고리즘 > BOJ' 카테고리의 다른 글

[BOJ] 9020 - 골드바흐의 추측  (0) 2018.05.02
[BOJ] 2581 - 소수, 1929 - 소수 구하기  (0) 2018.04.30
[BOJ] 1316 - 그룹 단어 체커  (0) 2018.04.16
[BOJ] 4344 - 평균은 넘겠지  (0) 2018.04.03
[BOJ] 10250 - ACM 호텔  (0) 2018.04.02
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/12   »
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
29 30 31
글 보관함