해결된 질문
작성
·
28
0
코드 리뷰를 한번 보고 로직을 작성했는데
처음에는 이 방식으로 작성했습니다
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
0
안녕하세요 ㅎㅎ
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
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;
이 방법은 현재 턴의 상태를 적절하게 비교하고, 앞선 턴의 값을 기반으로 방문 기록을 갱신합니다.
논리적 차이
visited
배열은 전 방한 여부를 추적하고, 그 안에 저장되는 값이 다음 상태로의 이동에 필요한 비용이나 경과 시간을 나타낼 수 있습니다.가능하면 기존 답변을 다음 게시글에서 확인해 보시길 권장드립니다:
두 코드를 비교하며 각각의 인덱싱 방식이 어떻게 문제를 해결하는지를 분석하시면 이해에 도움이 될 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
죄송합니다!! 링크 보내드렸습니다!
http://boj.kr/7a21c5fe5fa548f09c6f7a125085c667