inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

it 취업을 위한 알고리즘 문제풀이 입문 (with C/C++) : 코딩테스트 대비

64. 경로탐색 (그래프 DFS : Depth First Search)

64번 스택 오버플로우 뜨는 이유가 궁금합니다!

해결된 질문

394

김퍼블

작성한 질문수 9

0

제가 푼 방식은 정점이 n번까지 다다르면 카운트를 하나 올리고 방문여부를 체크하던 배열을 원상태로 초기화하는 방법입니다.

근데 이게 m이 작을 때는 잘 작동하는데 m이 커지는 순간 스택 오버플로우가 발생합니다..! 손그림 그려서 해봤는데 스택 오버플로우가 발생할 것 같기도 하고 왜 발생하는 건가 싶기도 해서 질문드립니다...(너무 긴가민가해서 좀 더 명쾌한 이유를 알고 싶어서요 ㅠㅠ)

#include<iostream>
using namespace std;
#include<vector>
#include<algorithm>
#include<string>

int n, m;  // 정점 n개, 간선 m개
vector<vector<int>> adjacent;  // -1은 연결 없음
vector<int> visited;
int ans = 0;

void DFS(int pre)  
{
	if (pre >= n)  // n에 다다르면 카운트 증가, 방문 배열 초기화
	{
		ans++;
		visited.clear();
		visited.resize(n + 1, 0);
		return;
	}

	visited[pre] = 1;  // 일단 방문했으니 체크

	for (int i = 1; i <= n; i++)
	{
                // 방문한 적 있거나 연결 끊겨있으면 continue해서 무시
		if (visited[i] == 1 || adjacent[pre][i] == -1)
			continue;
		DFS(i);  // 그 외라면 DFS 재귀호출
	}
}

int main(void)
{
	cin.tie(NULL);
	ios_base::sync_with_stdio(false);

	freopen("input.txt", "rt", stdin);  // 파일 입력받음

	cin >> n >> m;

	adjacent.resize(n + 1, vector<int>(n + 1, -1));
	for (int i = 0; i < m; i++)
	{
		int s, e;  // 시작 정점, 도착 정점
		cin >> s >> e;
		adjacent[s][e] = 1;
	}
	visited.resize(n + 1, 0);

	DFS(1);
	cout << ans;
}

아 그런데 스택 오버플로우 생기는 것 땜에 강사님 설명 봤고, 설명을 통해 고친 내용은 완벽히 이해된 상태입니다! 그냥 스택 오버플로우 발생 이유를 정확히 알고 싶어 질문드립니다 감사합니다

c++ 코딩-테스트

답변 1

0

김태원

안녕하세요^^

DFS는 기본적으로 백트랙킹인데 n번 정점에 갔을 때 visited를 초기화해버리면 안됩니다. n번 정점에 갔다고 해서 DFS함수가 1번 정점부터 다시 출발하는게 아니라 바로 전 재귀함수로 백을 합니다. 바로 전 함수나 전전 함수로 가서 이미 방문하고 온 정점을 체크를 풀어버렸기 때문에 다시 방문하게 되는 중복방문이 여러번 발생하게 되면서 스택 오버플로우가 생기는 것 같습니다.

0

김퍼블

계속 애매했는데 단번에 이해가 됐습니다..! 다 풀어버려서 다시 호출하니까 그런거였군요.. 감사합니다!!

87번 채점 프로그램에 오류가 있는 것 같습니다.

0

91

2

그리디 파트

0

115

2

안녕하세요. 선생님(54번 코드 관련 문의)

0

143

2

테스트 파일 exit_coe_1, time_limit_exceeded 질문

0

143

1

C언어로 코드를 짜면 채점 시에 한 문제 빼고 시간 초과가 발생하는데 해결하는 방법이 있을까요?

0

173

1

19번 질문있습니다

0

123

1

6번 관련 채점오류입니다

0

88

2

22번 문제는 C로 풀어주신 건가요 C++로 풀어주신 건가요?

0

166

2

dev C++ 콘솔창 바로 닫힘

0

245

1

최신화하기

0

171

1

채점이 안되요...

1

261

1

안녕하세요 강사님 정렬에 대해서 설명이 조금 더 듣고 싶습니다.

0

113

1

45번 공주구하기 문제를 list를 이용해서 이렇게 풀어도 될까요?

0

155

1

39번 두 배열 합치기 문제 채점 오류인가 코드 오류인가

0

155

0

채점기에서 틀렸다고 나오는데 이유를 모르겠습니다.

0

150

2

해당 강의에서 C언어로만 진행하는 강의 문의 건

0

145

2

87번 문제 섬나라 아일랜드 질문

0

128

1

16번 문제에서 직접 답을 대입하면 정답이 나오는데 채점에서 wrong answer가 나옵니다.

0

149

1

40번 교집합 문제

0

166

1

43번 뮤직비디오 문제 테스트케이스 4번을 만족 못합니다.

0

170

1

41. 연속된 자연수의 합 문제 질문있습니다.

0

166

1

질문있습니다.

0

193

2

시간초과가 나요

0

172

1

43번 문제 3 ~ 5번에 문제가 있는것 같습니다.

0

249

1