일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 다익스트라
- 이분매칭
- lca
- 위상정렬
- 누적합
- boj
- 삼분탐색
- 그리디
- 에라토스테네스의 체
- 플로이드와샬
- 브루트포스
- 수학
- 세그먼트트리
- 이분탐색
- BFS
- MST
- 백준
- 비트마스크
- lis
- 투포인터
- 이진탐색
- 정렬
- LazyPropagation
- DP
- 펜윅트리
- 좌표압축
- DisjointSet
- dfs
- 구현
- 크루스칼
Archives
- Today
- Total
lastknight00
[백준]민준이와 마산 그리고 건우(18223) 본문
문제 링크 : [백준]민준이와 마산 그리고 건우(18223)
문제 설명
1번 노드에서 V번까지 가는 최단거리가 1번에서 P번 노드를 거쳐 V번 노드까지 가는 최단거리보다 작거나 같은지 판별하세요.
입력
V(노드의 갯수, 1 <= V <= 5,000)
M(간선의 갯수, 1 <= M <= 10,000)
Ai Bi Ci(출발 노드, 도착 노드, 비용, 1 <= Ci <= 10,000)
6 7 4
1 2 1
1 3 1
2 3 10
3 4 1
3 5 2
4 5 1
5 6 1
출력
SAVE HIM
카테고리
#다익스트라
시간 복잡도 상한
O(M2)
해결 방법
- 1 -> V까지의 최단거리는 1번에서 시작하는 다익스트라를 통해 O(M * logM)만에 구할 수 있습니다.
- 양방향 그래프이기 때문에, 1 -> P의 최단거리는 P -> 1까지의 최단거리와 같습니다.
- 따라서 1 -> P -> V 로 가는 최단 거리는, P에서 시작하는 다익스트라를 구합니다.
- 그러면 P -> 1로 가는 최단거리 + P -> V로 가는 최단거리를 더하면 됩니다.
시간복잡도
O(M * logM)
코드
#include<cstdio>
#include<vector>
#include<queue>
#include<algorithm>
#include<string.h>
#define N 5001
using namespace std;
typedef pair<int,int>P;
int n,m,p,a,b,c,d[N],e[N],w[N];
vector<P>v[N];
priority_queue<P,vector<P>,greater<P>>q;
void r(int s,int d[]){
memset(w,0,sizeof(w));
q.push({0,s});
while(!q.empty()){
P x=q.top();q.pop();
if(w[x.second])continue;
w[x.second]=1;
d[x.second]=x.first;
for(P y:v[x.second])if(!w[y.second])q.push({x.first+y.first,y.second});
}
}
int main(){
scanf("%d%d%d",&n,&m,&p);
while(m--){
scanf("%d%d%d",&a,&b,&c);
v[a].push_back({c,b});
v[b].push_back({c,a});
}
r(1,d);
r(p,e);
printf("%s",d[n]<e[1]+e[n]?"GOOD BYE":"SAVE HIM");
}
'PS' 카테고리의 다른 글
[백준]미로에 갇힌 건우(18224) (0) | 2020.07.26 |
---|---|
[백준]무엇을 아느냐가 아니라 누구를 아느냐가 문제다(9694) (0) | 2020.07.20 |
[백준]브리징 시그널(3066) (0) | 2020.07.19 |
[백준]전구(2550) (0) | 2020.07.19 |
[백준]간선 이어가기 2(14284) (0) | 2020.07.19 |
Comments