3-K 플러드필 사용 안할경우 시간초과
447
작성한 질문수 17
안녕하세요 큰돌님
3-K를 강의듣기전에 풀어봤습니다.
플러드필을 사용하지 않고 풀어봤는데요
예제는 잘 통과하지만 시간초과가 났습니다.
그 이유를 생각해봤을때 얼음을 녹이고
다시 얼음을 녹이러 갈때 녹인 위치부터 탐색을 시작하는게 아니라 처음부터 탐색을 시작하기 때문인거같은데
제가 생각한게 맞을까요??
http://boj.kr/429e585816d54c2dafaa022e77f4c286
답변 1
0
안녕하세요 sol님 ㅎㅎ
네 맞습니다.
while(!is_meet){
ret++;
memset(visited,0,sizeof(visited));
for(int i = 0; i < N; i++){
for(int j = 0; j < M; j++){
if(board[i][j] == '.' && !visited[i][j]) {
visited[i][j];
dfs(i,j);
}
}
}앞의 코드를 보면.
계속해서 맵전체를 다시 탐색해서 >> dfs를 걸고 있죠? 그 때문에 시간초과가 나는 것같습니다.
근데 플루드필을 사용하면 계속해서 맵전체를 탐색하는 것이 아니라 녹은 그 지점부터 탐색을 이어나갈 수 있기 때문에 시간상 이점이 있습니다.
감사합니다.
0
감사합니다!
항상 알고리즘 공부할때 시간적인 효율면에서 애매한 부분을 그냥 넘겼는데 큰돌님 덕분에 자세히 알아가고 넘어갑니다!
마지막 강의까지 열심히 달리겠습니다ㅎㅎ
5-B
0
16
2
4 - A
0
33
2
코딩살구클럽 입장이 안됩니다
0
82
2
4-F 경우의 수 질문입니다.
0
35
2
코딩살구클럽 가입이 안됩니다.
0
85
2
살구 클럽에 대한 질문있습ㄴ디ㅏ
0
63
1
교안 158페이지 문의드립니다
0
47
2
코딩살구클럽 관련 건의사항
0
119
1
코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다
0
45
1
진행 방법 질문드립니다!
0
83
2
2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.
0
64
2
2주차 개념#12 트리 순회
0
33
2
백준사이트가 종료된다고 합니다.
0
318
2
백준 서비스 종료
9
953
1
sk 하이닉스 코테 대비
0
388
2
3-G 최댓값 질문
0
54
1
모듈러 연산 값이 10이 아닌 경우도 있지 않나요?
0
84
2
3-I 코드 질문드립니다.
0
66
2
3-N 질문 있습니다.
0
68
2
학습방법
0
105
2
4-H 질문 있습니다 (코드 리뷰)
0
69
2
코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.
0
186
2
2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.
0
74
2
2주차 개념 #4-2. 인접행렬 질문있습니다.
0
66
2





