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
1
0
살구 클럽에 대한 질문있습ㄴ디ㅏ
0
24
1
교안 158페이지 문의드립니다
0
30
2
코딩살구클럽 관련 건의사항
0
68
1
코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다
0
33
1
진행 방법 질문드립니다!
0
63
2
2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.
0
60
2
2주차 개념#12 트리 순회
0
29
2
백준사이트가 종료된다고 합니다.
0
289
2
백준 서비스 종료
9
901
1
sk 하이닉스 코테 대비
0
372
2
3-G 최댓값 질문
0
51
1
모듈러 연산 값이 10이 아닌 경우도 있지 않나요?
0
83
2
3-I 코드 질문드립니다.
0
62
2
3-N 질문 있습니다.
0
66
2
학습방법
0
102
2
4-H 질문 있습니다 (코드 리뷰)
0
66
2
코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.
0
173
2
2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.
0
69
2
2주차 개념 #4-2. 인접행렬 질문있습니다.
0
64
2
1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.
0
51
2
조합 재귀 풀이 확인 해주시면 감사하겠습니다.
0
68
2
함수별 시간복잡도
0
74
2
3-h 질문입니다.
0
49
1





