강의

멘토링

로드맵

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

tmddn_00님의 프로필 이미지
tmddn_00

작성한 질문수

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

4-K

4-K Tree판별문제 코드리뷰 부탁드리겠습니다.

작성

·

9

0

- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.

 

#include<bits/stdc++.h>

using namespace std;

int t,n,m, visited[1004];
vector<int> a[1004];


int solve(int before, int here){
    int ret = 1;
    visited[here]=1;
    for(int there: a[here]){
        if(there==before) continue;
        if(visited[there]) return -1000;

        ret += solve(here, there);
    };
    return ret;

}

int main(){
    cin>>t;
    while(t--){
        fill(visited,visited+1004,0);
        for(int i=0; i<1004; i++){
            a[i].clear();
        }
        cin>>n>>m;
        for(int i=0; i<m; i++){
            int temp1=0,temp2=0;
            cin>>temp1>>temp2;
            a[temp1].push_back(temp2);
            a[temp2].push_back(temp1);
        }

        if(n==solve(0,1)) cout<<"tree"<<'\n';
        else cout<<"graph"<<'\n';
    }

    return 0;
}

저는 dfs를 돌때 현재노드와 다음노드를 같이 넘겨서, 부모노드를 판별할 수 있게끔 했고, 부모노드가 아닌걸 재방문하면, 싸이클로 판별해서 쓰레기값이 들어가도록 코드를 짰습니다.

근데 큰돌님 코드는 0ms인데 제 코드는 4ms더라구요.. 어디에서 차이가 나는걸까요?ㅠㅠ

답변

답변을 기다리고 있는 질문이에요
첫번째 답변을 남겨보세요!
tmddn_00님의 프로필 이미지
tmddn_00

작성한 질문수

질문하기