inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

3-K와 문제의 단순화

3-K DFS

333

자르트

작성한 질문수 59

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번만에 얼음을 지우는 등의 활동을 할 수가 있는 것이죠.

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

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

 

 

감사합니다.

4 - A

0

22

2

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

0

60

2

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

0

32

2

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

0

74

2

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

0

54

1

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

0

44

2

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

0

114

1

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

0

44

1

진행 방법 질문드립니다!

0

80

2

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

0

63

2

2주차 개념#12 트리 순회

0

32

2

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

0

315

2

백준 서비스 종료

9

948

1

sk 하이닉스 코테 대비

0

385

2

3-G 최댓값 질문

0

54

1

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

0

84

2

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

0

65

2

3-N 질문 있습니다.

0

68

2

학습방법

0

105

2

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

0

69

2

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

0

182

2

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

0

72

2

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

0

65

2

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

0

53

2