해결된 질문
작성
·
105
0
안녕하세요 선생님 🙂
풀이를 보기 전에 먼저 문제를 풀어보았는데요, 이해가 되지 않는 부분이 있어서 질문 드립니다.
http://boj.kr/2d9dfe630895448f98babd79cb13b63f
기본적인 BFS에다 K의 값에 반복할수록 1씩 증가하는 cnt변수를 넣어줌으로써 경로의 횟수를 추적하려고 했는데요, 모든 경우에 K의 값이 50만이 넘어갑니다. 여기서 K의 값이 50만이 넘어가는 이유를 아무리 생각해도 모르겠어서 질문 드립니다.
항상 감사합니다 ^^
답변 1
1
안녕하세요 유태님 ㅎㅎ
int cnt = 1;
while (!q.empty())
{
int front = q.front();
q.pop();
for (const auto& f : { front + 1, front - 1, front * 2 })
{
if (K > 500000) break;
if (f < 0 || f > 500000) continue;
if (!visited[f])
{
q.push(f);
visited[f] = visited[front] + 1;
K += cnt;
cout << K << '\n';
cnt++;
K의 값이 50만이 넘어가는 이유는 자명합니다.
지금 보시면 k는 1, 2, 3, 4.... 가 더해지고 있고
총 3가지의 경우의 수마다 계속해서 +가 되고 있습니다.
그리고 이 코드는 최대 50만번 작동되겠죠? 0 ~ 50만이기 때문
즉, k에 1씩 더해지는 것도 아니고... 1, 2, 3, 4, 5.. 증가하는 숫자가 더해지니 50만 이상이 나오는 것은 자명합니다.
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
감사합니다 선생님!!