배열 참조가 재귀함수보다 속도가 빠른 것이 아닌가요?
1번은 제가 혼자 구현한 코드, 2번은 강의를 참고해서 로직을 살짝 바꾼 코드입니다.
강의에서는 visited를 매번 초기화하여 사용하였는데, 제 1번 코드에서는 visited를 초기화하지 않고 dp처럼 방문 가능 노드 갯수 값을 저장한 뒤 해당 값이 있으면 재귀함수를 수행하지 않고 바로 값을 가져오도록 하였습니다. 이렇게 하면 2번보다 당연히 시간이 빠를 것이라 생각했는데 오히려 1번이 시간초과가 발생하고 2번이 정답 처리되었습니다. 2번 방식은 visited가 매번 초기화되기 때문에 같은 값을 여러 번 계산하게 되고 1번은 childCount하나당 단 한 번만 계산하는데 속도가 더 느린 이유가 무엇인가요?
지금까지는 별 질문 없이 잘 풀다가 원래도 어려워했던 그래프에 도착하니 막히는 부분이 많아져서 질문을 부득이하게 여러 개 올리게 되었네요...도움 부탁드립니다!
답변 1
1
안녕하세요 경로님ㅎㅎ
해당 코드는 사이클을 해결하지 못합니다.
괜찮은 코드지만 해당 부분에서 많은 시간이 걸려서 시간초과가 뜨는 것 같습니다.
반례 :
3 3
1 2
2 1
1 3디버깅코드는 다음과 같습니다.
#include <bits/stdc++.h>
using namespace std;
vector<int> v[10000];
int n, m;
int visited[10000];
int arr[10000];
int childCount(int i){
cout << i << '\n';
if(visited[i]) return visited[i];
int ret = 1;
for(int n : v[i]){
if(visited[n]) ret+= visited[n];
else ret += childCount(n);
}
visited[i] = ret;
return ret;
}
int main()
{
ios_base::sync_with_stdio(0);cin.tie(0);
cin >> n >> m;
while(m--){
int a, b;
cin >> a >> b;
v[b-1].push_back(a-1);
}
int mx = 0;
for(int x = 0; x < n; x++){
if(!visited[x]) arr[x+1] = childCount(x);
else arr[x+1] = visited[x];
mx = max(arr[x+1], mx);
}
for(int x = 1; x < n+1; x++){
if(arr[x] == mx) cout << x << " ";
}
}
한번 실행해보시겠어요?
또 질문 있으시면 질문 부탁드립니다.
별점 5점과 좋은 수강평은 제게 큰 힘이 됩니다.
감사합니다.
4 - A
0
25
2
코딩살구클럽 입장이 안됩니다
0
63
2
4-F 경우의 수 질문입니다.
0
32
2
코딩살구클럽 가입이 안됩니다.
0
75
2
살구 클럽에 대한 질문있습ㄴ디ㅏ
0
55
1
교안 158페이지 문의드립니다
0
44
2
코딩살구클럽 관련 건의사항
0
116
1
코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다
0
44
1
진행 방법 질문드립니다!
0
81
2
2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.
0
63
2
2주차 개념#12 트리 순회
0
32
2
백준사이트가 종료된다고 합니다.
0
316
2
백준 서비스 종료
9
951
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
183
2
2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.
0
72
2
2주차 개념 #4-2. 인접행렬 질문있습니다.
0
65
2
1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.
0
53
2





