inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

3-K와 문제의 단순화

3-K DFS

335

자르트

작성한 질문수 60

0

dfs로 풀던 와중 시간 초과가 났습니다.

선생님과의 코드 로직이 비슷한데 다른 점이라면 저는 dfs를 시작하는 부분이 처음부터라는 것입니다. 선생님은 효율적으로 하기 위해 얼음을 녹인 부분부터 탐색하졌지만 저는 비효율적으로 움직인 것이지요. 그래서

코드를 보시면 아시겠지만

이번에 녹게 된 얼음을 water라는 벡터에 담고 그 위치를 기반으로 dfs를 했지만 시간 초과가 났습니다. 이유가 뭘까요..? 무조건 bfs로 풀어야 하는 문제인가요??!

http://boj.kr/a9dad7d86c01419d8b1cf0b6a8f8683c

c++ 코딩-테스트

답변 2

0

자르트

비효율적인 부분들이 쌓여있기 때문에 최대한 그런 것들 배제하고 코드를 짜야한다! 어떤 말씀인지 알았습니다! 그런데 예시를 들어주신 코드의 하단 부분에

이렇게 water를 새롭게 초기화를 해주고 있는데 이 코드로는 별 의미가 없는 건가요?? 나름 최적화 해보려고 처음부터가 아닌 새롭게 얼음에서 물이 된 애들만 녹는 것을 시도 했는데 이 방법이 아니였나욥

1

큰돌

네.. 저부분은 효율적이다라기보다는 그냥 로직자체를 수행하는 코드라고 보시면 됩니다.

0

큰돌

안녕하세요 자르트님 ㅎㅎ

	dfs(y, x);
	while (true) {
		// 하루 지남
		ret++;
		// 얼음 녹이기
		for (pair<int, int> pos : water) {
			removeIce(pos.first, pos.second);
		}

이 코드를 보면 계속해서 시작 지점부터 얼음을 녹이는 것을 볼 수 있습니다.

그러면 어떤 부분이 비효율적일까요?

image결국에는 이렇게 되지 않을까요? 예시를 든 그림에서 dfs는 얼음을 녹이기 위해 10번정도의 탐색을 하게 되는 것이죠.

이런 부분들의 비효율이 쌓여서 시간초과가 나는 거 같습니다.

하지만 큐 2개를 활용한 bfs에서는 저렇게 단 4번만에 얼음을 지우는 등의 활동을 할 수가 있는 것이죠.

다만, 이 문제같은 경우 시간초과가 정말 엄청 빡센 문제 중의 하나입니다.

그래서 최대한 효율적으로 짜야 하는 것도 있긴해서.. 좀 맞춰주셔야 하는 것도 있어요 ㅎㅎ

 

 

감사합니다.

코딩살구클럽 가입 문의

0

23

1

코딩 살구 클럽 컴파일 에러

0

18

1

추천 문제

0

18

1

코딩살구클럽 승인

0

24

1

코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의

0

32

2

문제를 고민하는 시간 관련

0

27

2

코딩살구클럽

0

42

2

코딩살구클럽 문의

0

45

2

코딩살구클럽 승인

0

37

2

DP 경우의 수 설명이 이해가 되지 않습니다.

0

35

2

3-F 채점 관련 질문

0

32

1

BFS, DFS 활용이 되는 상황에서의 방향성

0

34

2

코딩살구클럽 승인

0

46

2

코딩살구클럽승인

0

39

3

코딩살구클럽 승인

0

56

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

45

2

코살구 로그인 문제

0

65

2

3-A 문제 풀이 관련 질문

0

56

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

코딩 살구 클럽 접속 및 사용방법 문의

0

66

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

67

2

코딩살구클럽 로그인문제

0

85

3