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

AA66님의 프로필 이미지
AA66

작성한 질문수

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

3-I

3-I 질문있습니다.

작성

·

40

0

http://boj.kr/b1fa6325d50644dcad7a2f7adf22d925

틀린 코드이긴 하지만 왜 메모리 초과가 나는지 모르겠습니다.
저는 2차원배열을 쓰지 않아서 제일 큰 배열이 visited[MAX]가 500000의 크기를 갖는데 이것만으로도 메모리 초과가 나나요..?

그리고 여기서 좀만 수정하면 문제가 풀릴 것 같은데 어떻게 하면 좋을지 한 번 여쭤봐도 될까요? 이렇게는 풀수 없을까요?

답변 1

0

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

안녕하세요 ㅎㅎ

 

visited[MAX]가 500000의 크기를 갖는 것은 괜찮습니다.

 

		// 방문햇던곳도 재방문 가능하게 해야됨. 
		for(int next : {now-1, now+1, now*2}){
			if(next > 500000 || next < 0) continue;

방문한 지점을 재방문 함 -> queue에 불필요한 정점들이 많이 쌓이게 됨 + 루프가 많이 돔 -> 메모리초과가 나는 것 같습니다.

 

여기서 좀만 수정하면 문제가 풀릴 것 같은데

>> 1차원배열로는 풀지 못합니다. 먼저 2차원 배열로 바꾸시구 방문처리 관련 로직을 수정하셔야 합니다.

 

감사합니다.

AA66님의 프로필 이미지
AA66

작성한 질문수

질문하기