inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

2-S

배열 참조가 재귀함수보다 속도가 빠른 것이 아닌가요?

해결된 질문

365

이경로

작성한 질문수 7

0

1번은 제가 혼자 구현한 코드, 2번은 강의를 참고해서 로직을 살짝 바꾼 코드입니다.

  1. http://boj.kr/93dd64e4fe984863b6e61f8a7916e40c

  2. http://boj.kr/5a252acbbd6a450d92e338eeacc9a8ab

     

강의에서는 visited를 매번 초기화하여 사용하였는데, 제 1번 코드에서는 visited를 초기화하지 않고 dp처럼 방문 가능 노드 갯수 값을 저장한 뒤 해당 값이 있으면 재귀함수를 수행하지 않고 바로 값을 가져오도록 하였습니다. 이렇게 하면 2번보다 당연히 시간이 빠를 것이라 생각했는데 오히려 1번이 시간초과가 발생하고 2번이 정답 처리되었습니다. 2번 방식은 visited가 매번 초기화되기 때문에 같은 값을 여러 번 계산하게 되고 1번은 childCount하나당 단 한 번만 계산하는데 속도가 더 느린 이유가 무엇인가요?

 

지금까지는 별 질문 없이 잘 풀다가 원래도 어려워했던 그래프에 도착하니 막히는 부분이 많아져서 질문을 부득이하게 여러 개 올리게 되었네요...도움 부탁드립니다!

c++ 코딩-테스트

답변 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점과 좋은 수강평은 제게 큰 힘이 됩니다. 

감사합니다. 

0

이경로

visited를 맨 마지막에 설정하다 보니 사이클이 나오면 visited값을 가져오지 못하고 무한루프가 돌게 되는군요 감사합니다

코딩 살구 클럽 컴파일 에러

0

4

1

추천 문제

0

7

1

코딩살구클럽 승인

0

9

1

코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의

0

21

2

문제를 고민하는 시간 관련

0

26

2

코딩살구클럽

0

38

2

코딩살구클럽 문의

0

37

2

코딩살구클럽 승인

0

35

2

DP 경우의 수 설명이 이해가 되지 않습니다.

0

33

2

3-F 채점 관련 질문

0

31

1

BFS, DFS 활용이 되는 상황에서의 방향성

0

33

2

코딩살구클럽 승인

0

45

2

코딩살구클럽승인

0

39

3

코딩살구클럽 승인

0

54

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

63

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

67

2

코딩살구클럽 로그인문제

0

85

3

코딩 살구 클럽 로그인 문제

0

86

2