inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

3-D와 반례

3-d 불 메모리 초과 때문에 질문드립니다!

204

HMiso

작성한 질문수 7

0

안녕하세요 큰돌님, 언제나 좋은 강의 감사드립니다.

http://boj.kr/3ec7adf276a74ad89e779cb5b1839dbd

3-d 불 문제를 풀고있는데 계속해서 메모리 초과가 발생해서요.
혹시 몰라 큰돌님 예제 소스 확인했는데 로직상 거의 유사한것같은데 계속해서 메모리 초과가 발생하고 있습니다.
검토 한 번 부탁드려도 될까요?

다시 한번 좋은 강의 감사드립니다

c++ 코딩-테스트

답변 2

1

큰돌

안녕하세요 YeongJ님 ㅎㅎ

제가 이 코드를 여러번 보면서 틀린점을 찾느라 늦었습니다.

 

이런식으로 바꿔보시겠어요?

    fill(&visitedFire[0][0], &visitedFire[0][0] + 1001 * 1001, MAX); 
	for (int y = 0; y < r; y++)
	{
		for (int x = 0; x < c; ++x)
		{
			char input;
			cin >> input;
			if (input == '#') maps[y][x] = 1;
			else if (input == '.') maps[y][x] = 0;
			else if (input == 'F'){ 
                            maps[y][x] = 2; 
	                    visitedFire[y][x] = 1;
                            q.push(Pos(y,x));
                        }else if (input == 'J') J = Pos(y, x);
		}
	} 
    bfsFire(q); 

 

일단 for문 역순을 바꾸고

bfsfire 의 첫번째부분 -> visitedfire로 해야 하는데 visited로 한 실수를 바꿨고,

그리고 bfsFire부분을 한번에 실행시키는 것으로 바꿨습니다.

 

감사합니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

YeongJ님, 귀하의 3-D 불 문제 관련 메모리 초과 질문에 답변드립니다.

먼저, 메모리 초과는 프로그램이 할당된 메모리보다 많은 메모리를 사용할 때 발생합니다. 여러 원인이 있을 수 있지만, 대표적으로 크기가 큰 배열을 과도하게 사용하거나, 재귀 함수 호출 깊이가 너무 깊어질 때, 불필요한 메모리 할당이 반복될 때 등이 해당합니다.

관련하여 질문자님과 유사한 문제를 겪었던 다른 수강생의 경우와 강사님의 답변을 찾았습니다:

  • 3-D 불! 메모리 초과 질문에서 큰돌 강사님은 BFS 함수를 활용하여 메모리 초과 문제를 해결하는 방법에 대해 상세히 설명하셨습니다. 구체적으로 코드의 일부 영역이나 로직의 개선을 제안하셨는데, 예를 들어 특정 조건을 추가하여 불필요한 반복을 줄이거나, 메모리 사용을 최적화하는 방법 등이 있습니다. 해당 내용은 3-D 메모리 초과에서 확인하실 수 있습니다.

이와 유사한 상황이신 것 같습니다. 메모리 초과 문제는 개별 코드의 구조나 알고리즘 설계 방식에 따라 해결 방법이 달라질 수 있으므로, 여러 가지 접근 방법을 시도해 보시길 권장드립니다. 구체적으로 배열의 크기를 적절히 조정하거나, 불필요한 메모리 할당을 줄이는 등의 최적화 작업이 필요할 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.

현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏

추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

4-F 경우의 수 질문입니다.

0

9

1

코딩살구클럽 가입이 안됩니다.

0

29

0

살구 클럽에 대한 질문있습ㄴ디ㅏ

0

34

1

교안 158페이지 문의드립니다

0

34

2

코딩살구클럽 관련 건의사항

0

84

1

코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다

0

35

1

진행 방법 질문드립니다!

0

70

2

2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.

0

60

2

2주차 개념#12 트리 순회

0

32

2

백준사이트가 종료된다고 합니다.

0

296

2

백준 서비스 종료

9

909

1

sk 하이닉스 코테 대비

0

375

2

3-G 최댓값 질문

0

52

1

모듈러 연산 값이 10이 아닌 경우도 있지 않나요?

0

84

2

3-I 코드 질문드립니다.

0

63

2

3-N 질문 있습니다.

0

68

2

학습방법

0

103

2

4-H 질문 있습니다 (코드 리뷰)

0

67

2

코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.

0

176

2

2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.

0

70

2

2주차 개념 #4-2. 인접행렬 질문있습니다.

0

65

2

1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.

0

52

2

조합 재귀 풀이 확인 해주시면 감사하겠습니다.

0

69

2

함수별 시간복잡도

0

75

2