알고리즘/BOJ
[백준] 5214 환승
세진짱
2020. 3. 31. 14:35
옛날에 풀어본 문제여서 다시 풀어보려고 했는데 탈탈 털렸다
옛날에는 어떻게 풀었을까? 도움을 받았었나 ㅎㅎ
이 문제는 하이퍼링크는 연결되어있기 때문에 안에서는 비용이 안들고
하이퍼링크를 넘어갈 때는 비용이 든다는걸 그래프로 표현해야한다
어떻게 해야할까..!
그래프를 만들때 (N+M)개의 정점으로 만들어주면 된다!
1~N 까지는 정점이고 (N+1 + M)까지는 바로 하이퍼링크..!
내가 어떤 점 X 가 하이퍼링크 K에 속해있다면
그래프 X에서는 갈 수 있는 하이퍼링크 K에 연결시켜주고 1의 비용이 들고
반대로 하이퍼링크 K 에서는 갈 수 있는 점들 X를 연결하고
하이퍼링크 안에서 이동이므로 비용은 0이 된다!
그래서 그래프를 만들면
X -> K (비용 1) 하이퍼링크 밖에서 이동 (정점 X를 가진 하이퍼링크 K로 이동)
K -> X (비용 0) 하이퍼링크 안에서 이동 (하이퍼링크 K에 속한 정점들로 이동)
이런 개념으로 만들어진다
어렵다..!
어떻게 생각할까 이런건 ㅎㅎ
그래프를 그려준다면 그 다음엔 최단거리 알고리즘으로 변한다!
다익스트라를 사용했다
소스코드
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
35
36
37
38
39
40
41
|
#include <bits/stdc++.h>
using namespace std;
#define ll long long
int n,m,k;
const int MAXN =1e5+5;
int d[MAXN+1111];
int main(){
scanf(" %d %d %d",&n,&k,&m);
memset(d,-1,sizeof(d));
vector<vector<pair<int,int>>> Graph(n+m+1);
for(int i=n+1;i<n+m+1;i++){
for(int j=0;j<k;j++){
int x; scanf(" %d",&x);
Graph[x].push_back({i,1});
Graph[i].push_back({x,0});
}
}
priority_queue<pair<int,int>> pq;
pq.pop();
if(d[now] != -1) continue;
d[now]=cost;
for(int i=0;i<Graph[now].size();i++){
int next = Graph[now][i].first;
int ncost = -cost -Graph[now][i].second;
}
}
printf("%d\n",(d[n]==-1) ? -1 : d[n]+1);
}
|