3-I 질문있습니다 :)
안녕하세요 선생님 🙂
풀이를 보기 전에 먼저 문제를 풀어보았는데요, 이해가 되지 않는 부분이 있어서 질문 드립니다.
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점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
코딩살구클럽 문의
0
7
1
코딩살구클럽 승인
0
19
2
DP 경우의 수 설명이 이해가 되지 않습니다.
0
27
2
3-F 채점 관련 질문
0
24
1
BFS, DFS 활용이 되는 상황에서의 방향성
0
28
2
코딩살구클럽 승인
0
41
2
코딩살구클럽승인
0
33
3
코딩살구클럽 승인
0
48
2
3-D 관련 질문
0
35
2
코살구 회원가입 문의
0
43
2
코살구 로그인 문제
0
65
2
3-A 문제 풀이 관련 질문
0
53
3
2-O 질문 있습니다
0
38
2
2-T 문제에 관한 질문
0
40
2
코딩 살구 클럽 접속 및 사용방법 문의
0
61
2
안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~
0
64
2
코딩살구클럽 로그인문제
0
78
3
코딩 살구 클럽 로그인 문제
0
82
2
2-J 채점관련 질문
0
65
3
코딩 살구 클럽 Python 지원 가능 여부
0
77
1
살구클럽 아이디 없음 문제
0
76
1
1-O 코딩살구클럽 채점관련 질문
0
60
2
히든 테스트 케이스가 사라졌습니다
0
57
1
채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요
1
74
2





