Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 플로이드 와샬
- 너비 우선 탐색
- 완전탐색
- brute force
- 하카타역
- 깊이 우선 탐색
- 삼성 SW 테스트
- DP
- 완전 탐색
- 삼성시험
- deque
- 삼성테스트
- dfs
- 후쿠오카 여행경비
- IOS
- queue
- 큐
- 시뮬레이션
- BOJ
- 백준
- 다이나믹 프로그래밍
- 후쿠오카 캐널시티
- 후쿠오카 요도바시 하카타
- 후쿠오카
- 일본 여행
- 플로이드
- 알고리즘
- 후쿠오카 4박 5일
- 미로찾기
- BFS
Archives
- Today
- Total
맛있는감귤
BOJ : 11657 타임머신 본문
문제 : https://www.acmicpc.net/problem/11657
최단거리를 찾는 문제같은데 타임머신이 있거나 시간을 역행하는 문제, 음수 가중치가 존재하는 대다수의 문제는 벨만-포드 알고리즘으로 해결가능합니다.
다익스트라 알고리즘 같은 경우 해당 노드에 존재하는 간선을 보고 가중치가 가장 작은 값을 선택하게 됩니다.
그렇기 때문에
A -> B -> C / A -> C 의 루트에서
1 5 -4 1 3
의 값을 가질 때
노드 A의 간선의 가중치 5와 3만을 비교하기 때문에 원하는 답을 도출할 수 없습니다.
왜냐하면 1 -> 5 -> -4이 더 최단 거리가 되기 때문이죠.
그렇기 때문에 간선을 비교하고 또 노드의 개수-1만큼 또 비교를 해주면 됩니다. (도착지 노드까지 가는 간선은 전체 노드개수를 넘지 않기 때문)
하지만 그래프 특성상 사이클이 생길 수도 있는데 음수 값이 들어간다면 음수 값으로 갱신 되는 일이 발생하겠죠.
이를 음수 싸이클 혹은 음의 싸이클(Negative Cycle)이라고 합니다.
해당 문제에서는 음수 싸이클이 발생하면 -1을 출력하라고 하니, N-1까지 돌고 N번째 반복문을 돌 때 값이 갱신되는 부분이 있으면 -1을 출력해주면 됩니다.
#include <cstdio> #include <vector> using namespace std; #define INF 987654321 int main(){ int N,M; int dist[502]; bool cycle = false; vector<pair<int, int>> v[502]; scanf("%d%d",&N,&M); for(int i=0;i<M;i++){ int A,B,C; scanf("%d%d%d",&A,&B,&C); v[A].push_back(make_pair(B, C)); } for(int i=1;i<=N;i++) dist[i]=INF; dist[1] = 0; for(int i=1;i<=N;i++){ for(int j=1;j<=N;j++){ for(auto &n : v[j]){ if(dist[j] != INF && dist[n.first] > n.second + dist[j]){ dist[n.first] = n.second + dist[j]; if(i == N) cycle = true; } } } } if(cycle) printf("-1\n"); else{ for(int i=2;i<=N;i++) if(dist[i]==INF) printf("-1\n"); else printf("%d\n",dist[i]); } }
'알고리즘 > 백준 알고리즘' 카테고리의 다른 글
BOJ : 14442 벽 부수고 이동하기2 (0) | 2017.03.26 |
---|---|
BOJ : 9095 1,2,3 더하기 (0) | 2017.03.26 |
BOJ : 9517 아이 러브 크로아티아 (0) | 2017.03.15 |
BOJ : 1726 로봇 (0) | 2017.03.15 |
BOJ : 1991 트리 순회 (0) | 2017.03.15 |