3-I 질문있습니다!
코드 리뷰를 한번 보고 로직을 작성했는데
처음에는 이 방식으로 작성했습니다
if (visited[(turn+1) % 2][next]) continue;
visited[(turn+1) % 2][next] = visited[(turn) % 2][now] + 1;
500000 0 을 입력했을 때 999가 나오면서 오답인데
선생님 코드는
if (visited[(turn) % 2][next]) continue;
visited[(turn) % 2][next] = visited[(turn +1) % 2][now] + 1;
으로 -1 나오면서 정답인데
두 코드간의 차이를 모르겠습니다
답변 3
1
안녕하세요 ㅎㅎ
visited[0][n] = 1;
q.push(n);
if (n == k)
{
cout << 0 << "\n";
return 0;
}
while (q.size())
{
k += trun;
if (k > MAX) break;
if (visited[trun % 2][k])
{
ok = true;
break;
}
int size = q.size();
for (int i = 0; i < size; ++i)
{
int now = q.front();
q.pop();
for (int next : {now + 1, now - 1, now * 2})
{
if (next <0 || next >MAX) continue;
if (visited[(trun+1) % 2][next]) continue;이렇게 하게 되면 의미자체가 틀린 코드가 됩니다.
저 for문안에서 하고자 하는 것은 지금의 trun에서 next라는 정점을 갔을 때의 방문을 확인하는 코드인데요.
저기서 + 1을 기반으로 하게 되면 해당 의미가 깨져서 틀리게 됩니다.
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
0
안녕하세요 mch님ㅎㅎ
오랜만이네요.
저렇게 할경우에는 turn에 따른 부분을 좀 조정해주어야 할 것 같은데요. 전체 코드 부탁드립니다.
감사합니다.
0
안녕하세요, 인프런 AI 인턴입니다.
mch473700님께서 문의 주신 코드에 대한 이해를 돕기 위해 추가 설명을 드리겠습니다.
님께서 질문하신 코드 로직에서 사용하는 visited 배열의 인덱스 접근 방식 차이로 인해 결과가 다르게 나오는 것 같습니다.
구체적으로 살펴보면:
코드 차이점
님의 방법:
if (visited[(turn+1) % 2][next]) continue; visited[(turn+1) % 2][next] = visited[(turn) % 2][now] + 1;이 방법은 다음 턴의 상태를 방문했는지 체크하고, 방문 기록을 갱신하려고 시도합니다. 이는 논리적인 오류를 발생시킬 수 있습니다.
선생님의 방법:
if (visited[(turn) % 2][next]) continue; visited[(turn) % 2][next] = visited[(turn +1) % 2][now] + 1;이 방법은 현재 턴의 상태를 적절하게 비교하고, 앞선 턴의 값을 기반으로 방문 기록을 갱신합니다.
논리적 차이
- BFS와 같은 탐색 알고리즘에서
visited배열은 전 방한 여부를 추적하고, 그 안에 저장되는 값이 다음 상태로의 이동에 필요한 비용이나 경과 시간을 나타낼 수 있습니다.
- 선생님의 방법은 “현재 턴”과 “직전 턴” 정보를 올바르게 활용하여 이동 경로를 추적 및 계산하여 정확한 결과를 내는 것으로 보입니다.
- BFS와 같은 탐색 알고리즘에서
가능하면 기존 답변을 다음 게시글에서 확인해 보시길 권장드립니다:
두 코드를 비교하며 각각의 인덱싱 방식이 어떻게 문제를 해결하는지를 분석하시면 이해에 도움이 될 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
DP 경우의 수 설명이 이해가 되지 않습니다.
0
8
1
3-F 채점 관련 질문
0
15
1
BFS, DFS 활용이 되는 상황에서의 방향성
0
20
2
코딩살구클럽 승인
0
25
2
코딩살구클럽승인
0
22
3
코딩살구클럽 승인
0
43
2
3-D 관련 질문
0
33
2
코살구 회원가입 문의
0
40
2
코살구 로그인 문제
0
61
2
3-A 문제 풀이 관련 질문
0
52
3
2-O 질문 있습니다
0
38
2
2-T 문제에 관한 질문
0
39
2
코딩 살구 클럽 접속 및 사용방법 문의
0
59
2
안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~
0
64
2
코딩살구클럽 로그인문제
0
75
3
코딩 살구 클럽 로그인 문제
0
79
2
2-J 채점관련 질문
0
65
3
코딩 살구 클럽 Python 지원 가능 여부
0
77
1
살구클럽 아이디 없음 문제
0
76
1
1-O 코딩살구클럽 채점관련 질문
0
60
2
히든 테스트 케이스가 사라졌습니다
0
57
1
채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요
1
74
2
살구 클럽 채점 관련 문의(테스트 케이스)
0
66
2
1-H 문제 채점하기 오류
0
58
3





