3-K DFS
335
작성한 질문수 60
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);
}이 코드를 보면 계속해서 시작 지점부터 얼음을 녹이는 것을 볼 수 있습니다.
그러면 어떤 부분이 비효율적일까요?
결국에는 이렇게 되지 않을까요? 예시를 든 그림에서 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





