inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

7-C

7 - C 질문

195

eogmlrhtn

작성한 질문수 2

0

dfs 방식으로 풀었는데 메모리초과가 발생해 질문드립니다.

재귀함수이다보니 함수호출이 잦아 발생하는거 같은데,

해당 위치에서, 해당 위치에 도달하는 경로 중 가장 많이 이동한 경로만을 탐색하는 방식으로 진행했음에도 불구하고 메모리초과가 발생하다보니 어디가 문제인지 모르겠어서 질문드립니다 ㅜㅜ...

 

#include <bits/stdc++.h>

using namespace std;

enum
{ E,
  S,
  W,
  N,
};

// moves : 해당 위치에 도착했을 때, 지금까지 내가 몇번 움직였는지를 저장한다.
int table[51][51], moves[51][51];
int n, m;
int dy[4] = {0,1,0,-1}, dx[4] = {1,0,-1,0};

// dfs, 이동 가능한 방향으로 이동하는 함수
void go(int fy, int fx, int y, int x, int cnt)
{	
	// 움직인 횟수 저장
	moves[y][x] = cnt;
	
	for(int i = E; i < N; i++)
	{
		int ny = y + dy[i]*table[y][x], nx = x + dx[i]*table[y][x];

        // 최대 횟수로 이동한 경로만 통과 가능
		if(ny < 0 || nx < 0 || ny >= n || nx >= m || table[ny][nx] == 0 || cnt + 1 < moves[ny][nx]) continue;
        
        // 무한 루프에 빠지게 될 경우, 탈출
		if(fy == ny && fx == nx)
		{
			exit(0);
		}
		go(y, x, ny,nx, cnt + 1);
	}
}

int main()
{
	ios_base::sync_with_stdio(false);
	cin.tie(NULL); cout.tie(NULL);
	
	cin >> n >> m;
	for(int i=0; i<n; i++)
	{
		for(int j=0; j<m; j++)
		{
			char tmp;
			cin >> tmp;
			if(tmp == 'H')
			{
				tmp = '0';
			}
			table[i][j] = tmp - '0';
		}
	}
	
	go(0,0,0,0,1);
	
	cout << *max_element(moves[0], moves[0] + 51*51);		
		
	return 0;
} 

c++ 코딩-테스트

답변 2

0

큰돌

안녕하세요 ㅎㅎ

재귀함수이다보니 함수호출이 잦아 발생하는거 같은데,

>> 네 저도 그런 거 같고.. 사실 괜찮은 생각이시긴 해요. cnt를 기반으로 호출을 줄이는 생각도 좋고 마지막 max부분도 좋네요.

다만 근데 이렇게 되면

 cnt + 1 < moves[ny][nx]) continue;

앞의코드를 기반으로 봤을 때 cnt + 1 == moves[ny][nx]의 경우에는 해당 부분에 대해서 걸러지지 않을 것 같아요.

그래서 제가 이렇게도 해봤는데 똑같이 메모리 초과가 뜨네요...

 cnt + 1 <= moves[ny][nx]) continue; 

 

조금 더 보고 어떤 점이 비효율적인지 찾으면 다시 답변드리겠습니다.

 

감사합니다.

0

인프런 AI 인턴

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

질문하신 내용에 대해 C++에서 재귀함수를 이용한 DFS로 메모리 초과 문제를 해결하는 사례와 유사한 질문을 발견했습니다. 아래 링크에서 질문자님이 겪고 계신 문제에 대한 해결 방법을 찾을 수 있습니다.

질문하신 코드에서 메모리 초과 문제가 발생하는 이유 중 하나는 재귀 호출의 깊이가 매우 깊어지기 때문일 수 있습니다. 이 경우, 재귀함수 대신 다른 방식을 고려해보거나, 메모리 사용을 줄이는 여러 최적화 방안을 모색해볼 필요가 있습니다. 예를 들어, 방문 여부를 확인하는 추가적인 로직을 도입하거나, 필요 없는 메모리 사용을 절약하기 위해 전역 변수 대신 지역 변수를 적절히 활용하는 방법 등이 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

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

0

17

2

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

0

41

2

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

0

38

1

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

0

37

2

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

0

88

1

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

0

38

1

진행 방법 질문드립니다!

0

71

2

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

0

61

2

2주차 개념#12 트리 순회

0

32

2

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

0

298

2

백준 서비스 종료

9

911

1

sk 하이닉스 코테 대비

0

377

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

177

2

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

0

70

2

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

0

65

2

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

0

52

2

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

0

69

2

함수별 시간복잡도

0

75

2