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

김동훈님의 프로필 이미지
김동훈

작성한 질문수

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

3-N

3-D 질문있습니다

작성

·

346

0

안녕하세요, 큰돌님

강의와 비슷한 로직인것 같은데, 메모리초과 되어 질문합니다!

메모리초과가 나는 이유를 모르겠습니다ㅣ.

 

K가 10일때, 2^1024만큼 go함수를 호출해서 틀린건가 싶기도 합니다...

답변 3

0

큰돌님의 프로필 이미지
큰돌
지식공유자

동훈님 안녕하세요 ㅎㅎ 대댓글 달면 알림이 안뜰까봐 이리로 답니다.

이렇게 수정하시면 됩니다.

vector같은 경우 10번째 요소에 접근할 수 있기 때문에 11로 설정해주셔야 합니다.

항상 배열은 좀 더 크게 잡는게 중요합니다.

vector<int> A[11];
int a[1024]; 
void go(int start,int end, int depth){

 

나머지 코드는 훌륭합니다.

 

감사합니다.

김동훈님의 프로필 이미지
김동훈
질문자

K가 3일때, depth는 0에서 시작해서 3까지 가서 재귀를 탈출하네요

그래서 11로 크기를 잡아야하는군요...
덕분에 이해 됐습니다!
감사합니다!!

0

큰돌님의 프로필 이미지
큰돌
지식공유자

안녕하세요 동훈님 ㅎㅎ

코드 공유 부탁드립니다.

김동훈님의 프로필 이미지
김동훈
질문자

https://www.acmicpc.net/source/61647388

죄송합니다..
코드링크를 게시 안했네요

0

안녕하세요, 인프런 AI 인턴이에요.

3-D 질문에 대해서 답변해드리겠습니다. 메모리 초과 에러가 발생하는 이유는 어디서 메모리를 많이 사용하는지 파악해 보시는 것이 좋습니다. 또는 배열 선언이나 함수 호출 등에서 공간을 많이 사용하는 부분이 있지는 않은지 확인해보시기 바랍니다.

크은돌님 강의와 비슷한 로직을 사용하신것 같습니다. 제가 구체적으로 코드를 볼 수 없기 때문에 어떤 부분에서 메모리 초과가 일어나는지 판단하기 어렵습니다. 그러나, K가 크다면 회귀에 의한 불필요한 재귀호출이 많이 일어날 수 있으므로, 단순 재귀법이 아닌 반복적 동적 할당, 그리고 DP 캐시배열 등을 이용하면 성능 향상을 기대할 수 있을 것입니다.

더 자세한 것은 코드를 꼼꼼하게 분석해 보시기를 권해드립니다. 주어진 입력에 비해 많은 메모리를 사용하는 문제는 다양한 원인 때문에 발생할 수 있기 때문입니다.

질문이 있으시면 언제든지 댓글로 답변해드리겠습니다. 감사합니다.

김동훈님의 프로필 이미지
김동훈

작성한 질문수

질문하기