티스토리 뷰

 

사이클 중 가중치의 합이 가장 작은 사이클의 길이를 출력하는 문제다

N이 크면 다른방법을 쓰겠지만 N이 작아서 그냥 완탐을 돌렸다

 

모든정점에서 시작해서 해당 정점으로 돌아오는 사이클을 찾고 비교하면 된다

근데 이상하게 가지치기를 하니까 정답이고 안하니까 테케 3개가 틀린다

왜일까..! 가지치기 안해도 다시 시작점으로 돌아올 때 min값을 초기화하면 

답이 나올거라고 생각했는데..! 아직 의문이다

 

ans>sum+cost 이 부분을 빼면 틀린다..!

아시는분..!

 

소스코드

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#include <bits/stdc++.h>
using namespace std;
#define ll long long
int t,n,m;
bool check[404];
const int inf = 1600000005;
int ans =inf;
void dfs(int now,int sum,int start,vector<vector<pair<int,int>>>& Graph){
    check[now]=true;
    for(int i=0;i<Graph[now].size();i++){
        int next = Graph[now][i].first;
        int cost = Graph[now][i].second;
        if(!check[next] && ans>sum+cost) dfs(next,sum+cost,start,Graph);
        if(start==next) ans = min(ans,sum+cost);
    }
}
int main(){
    scanf(" %d",&t);
    for(int tc=1;tc<=t;tc++){
        scanf(" %d %d",&n,&m); ans=inf;
        vector<vector<pair<int,int>>> Graph(n+1);
 
        for(int i=0;i<m;i++){
            int x,y,z; scanf(" %d %d %d",&x,&y,&z);
            Graph[x].push_back({y,z});
        }
        for(int i=1;i<=n;i++) {
            memset(check,0,sizeof(check));
            dfs(i,0,i,Graph);
        }
        if(ans==inf) ans=-1;
        printf("#%d %d\n",tc,ans);
    }
}
 
 

'알고리즘 > SW Expert Academy' 카테고리의 다른 글

[SWEA] 7793. 오! 나의 여신님  (0) 2020.03.09
[SWEA] 7396 종구의 딸 이름 짓기  (0) 2020.03.06
[SWEA] 7988 내전 경기  (0) 2020.03.04
[SWEA] 8275 햄스터  (0) 2020.03.04
[SWEA] 1907 모래성 쌓기  (0) 2020.03.03
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
TAG
more
«   2024/04   »
1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30
글 보관함