해결된 질문
작성
·
56
·
수정됨
1
- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.
dfs 의 매개 변수로 vector 를 넘겨줄 때 코드입니다 .
http://boj.kr/129282969aaf44f28f97cf1b1024ad1e
vector 를 전역변수로 했을 때 코드입니다.
http://boj.kr/74480c35c04441f2860defc1634e0e0a
두 코드 모두 예제는 맞추는데 제출하면 틀렸다고 나와서 코드확인 부탁드립니다!
답변 2
0
안녕하세요 인준님 ㅎ
전역변수나 지역변수로 넘기는것과는 상관없이 틀린 부분이 있어서 그런 것 같습니다.
abs(nation[ny][nx] - nation[y][x] <= R))
abs 부분 )이 잘못되었습니다.
if (abs(nation[ny][nx] - nation[y][x]) >= L && abs(nation[ny][nx] - nation[y][x]) <= R)
이렇게 되어야 합니다.
감사합니다.
0
안녕하세요, 인프런 AI 인턴입니다.
제공하신 정보의 범위 내에서 직접적인 코드 리뷰나 디버깅을 진행할 수는 없습니다. 하지만, 일반적인 dfs와 벡터 사용 시 자주 발생할 수 있는 문제들에 대해 조언 드리겠습니다.
깊은 복사와 얕은 복사: 벡터를 매개변수로 넘길 때, 값에 의한 호출(value)과 참조에 의한 호출(reference) 사이의 차이를 확인하세요. 값에 의한 호출을 사용하면 벡터의 깊은 복사가 발생해 성능 저하가 생길 수 있습니다. 참조에 의한 호출을 사용하면 이를 방지할 수 있습니다.
전역 변수 사용의 부작용: 전역 변수를 사용할 때는 다른 함수나 코드에서 의도치 않게 변경되지 않도록 주의해야 합니다. 전역 변수의 값이 어디서든 변경될 수 있기 때문에 디버깅이 어려워질 수 있습니다.
초기화 문제: dfs 실행 전 후에 벡터가 제대로 초기화 되는지 확인해 보세요. 불필요한 데이터가 남아있거나 초기화되지 않는 경우 예상치 못한 결과를 초래할 수 있습니다.
메모리 초과: dfs 실행 시 깊은 재귀로 인해 스택 메모리를 많이 사용할 수 있습니다. 재귀의 깊이를 제한하거나, 필요없는 메모리 사용을 줄일 방법을 고려해 보세요.
위의 조언들이 문제 해결에 도움이 되었으면 좋겠습니다. 구체적인 코드 분석이나 더 자세한 질문이 있으면, 해당 강의의 Q&A 섹션을 활용하거나 주제에 맞는 커뮤니티, 포럼에서 도움을 요청하는 것이 좋을 것 같습니다.
원하는 답변을 찾지 못하셨나요? 그럼 우측 하단의 ‘문의하기’ 에서 직접 문의해주세요. 최대한 빠르게 답변드리도록 하겠습니다!