작성
·
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차원 배열로 바꾸시구 방문처리 관련 로직을 수정하셔야 합니다.
감사합니다.