인프런 커뮤니티 질문&답변

전인준님의 프로필 이미지
전인준

작성한 질문수

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

3-C

3-C 코드확인 부탁드립니다.

해결된 질문

작성

·

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와 벡터 사용 시 자주 발생할 수 있는 문제들에 대해 조언 드리겠습니다.

  1. 깊은 복사와 얕은 복사: 벡터를 매개변수로 넘길 때, 값에 의한 호출(value)과 참조에 의한 호출(reference) 사이의 차이를 확인하세요. 값에 의한 호출을 사용하면 벡터의 깊은 복사가 발생해 성능 저하가 생길 수 있습니다. 참조에 의한 호출을 사용하면 이를 방지할 수 있습니다.

  2. 전역 변수 사용의 부작용: 전역 변수를 사용할 때는 다른 함수나 코드에서 의도치 않게 변경되지 않도록 주의해야 합니다. 전역 변수의 값이 어디서든 변경될 수 있기 때문에 디버깅이 어려워질 수 있습니다.

  3. 초기화 문제: dfs 실행 전 후에 벡터가 제대로 초기화 되는지 확인해 보세요. 불필요한 데이터가 남아있거나 초기화되지 않는 경우 예상치 못한 결과를 초래할 수 있습니다.

  4. 메모리 초과: dfs 실행 시 깊은 재귀로 인해 스택 메모리를 많이 사용할 수 있습니다. 재귀의 깊이를 제한하거나, 필요없는 메모리 사용을 줄일 방법을 고려해 보세요.

위의 조언들이 문제 해결에 도움이 되었으면 좋겠습니다. 구체적인 코드 분석이나 더 자세한 질문이 있으면, 해당 강의의 Q&A 섹션을 활용하거나 주제에 맞는 커뮤니티, 포럼에서 도움을 요청하는 것이 좋을 것 같습니다.

원하는 답변을 찾지 못하셨나요? 그럼 우측 하단의 ‘문의하기’ 에서 직접 문의해주세요. 최대한 빠르게 답변드리도록 하겠습니다!

전인준님의 프로필 이미지
전인준

작성한 질문수

질문하기