인프런 커뮤니티 질문&답변

자르트님의 프로필 이미지
자르트

작성한 질문수

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

3-K와 문제의 단순화

3-K DFS

작성

·

295

·

수정됨

0

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

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

코드를 보시면 아시겠지만

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

http://boj.kr/a9dad7d86c01419d8b1cf0b6a8f8683c

답변 2

0

자르트님의 프로필 이미지
자르트
질문자

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

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

큰돌님의 프로필 이미지
큰돌
지식공유자

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

0

큰돌님의 프로필 이미지
큰돌
지식공유자

안녕하세요 자르트님 ㅎㅎ

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

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

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

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

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

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

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

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

 

 

감사합니다.

자르트님의 프로필 이미지
자르트

작성한 질문수

질문하기