작성
·
122
0
안녕하세요! 숨바꼭질 문제를 풀다가 trace 배열을 만드는 것 말고, visited의 값 만을 이용해 문제를 풀 수 있을 것 같아서 다음과 같이 코드를 작성했습니다.
http://boj.kr/ef5e639dacc44c76a86baa28a9d967b8
visited값에 대한 map을 만들어 값을 역추적 해 나갔습니다! 근데 48% 쯤에서 틀렸다고 나오네요,,, 백준 질문게시판에 적힌 반례들을 모두 넣어봐도 적절한 반례를 못찾겠습니다ㅠㅠㅠ
답변 2
1
안녕하세요 jwoo님 ㅎㅎ
정말 잘 짜셨네요 ㅎㅎ
후... 틀린 부분 찾느라 고생좀 했습니다 ㅎㅎ
for(auto nn : {n+1, n-1, n*2}) {
if(nn < 0 || nn >= MAX) continue;
이렇게 바꿔보시겠어요? 배열범위를 10으로 설정했으면 인덱스 - 10을 참조하지는 않게 해야합니다.
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
0
안녕하세요, 인프런 AI 인턴입니다.
님의 질문에 직접적으로 답변 드리기는 어려울 것 같아요. 정보 내용에는 “숨바꼭질 문제”나 “백준(BOJ)의 특정 문제에 대한 해결책이나 코드 검토”에 관련된 내용이 없습니다. 그러나 일반적으로 코드가 특정 지점에서 오답을 반환할 때 몇 가지 방법으로 접근해 볼 수 있습니다.
로직 검토: visited
값을 사용해 역추적하는 로직이 정확한가 다시 한번 확인하세요. 특히 모든 경우의 수를 올바르게 처리하고 있는지 검토합니다.
경계 조건 검사: 문제의 경계 조건을 다시 한번 확인하세요. 종종 문제의 입력 범위나 조건을 잘못 이해하여 코드를 작성하는 경우가 있습니다.
다른 방법으로 접근하기: 만약 가능하다면, 다른 방법으로 문제를 접근해 보세요. 예를 들어, trace
배열을 사용한 전형적인 방법으로 문제를 해결해 본 후, 그 해결 방법과 visited
값만을 사용하는 방법을 비교해 보는 것입니다.
커뮤니티 도움 요청: 백준 온라인 저지 같은 플랫폼의 커뮤니티나 스택 오버플로우, 깃허브 같은 곳에서 질문을 올려 도움을 요청해 볼 수도 있습니다. 코드 전체나 특정 부분을 공유하며 틀린 부분을 지적해 달라고 요청합니다.
문제 해결에 도움이 되시길 바랍니다.
세상에,,, 저 부분을 생각하지 않았네요! 친절한 답변 정말 감사합니다ㅎㅎㅎ