Submission #3546117
Source Code Expand
#include<iostream>
#include<vector>
#include<algorithm>
#include<cctype>
#include<utility>
#include<string>
#include<cmath>
#include<numeric>
#include<map>
#include<cstdio>
#include<queue>
#define REP(i, n) for(int i = 0;i < n;i++)
#define REPR(i, n) for(int i = n;i >= 0;i--)
#define FOR(i, m, n) for(int i = m;i < n;i++)
#define FORR(i, m, n) for(int i = m;i >= n;i--)
#define SORT(v, n) sort(v, v+n);
#define VSORT(v) sort(v.begin(), v.end());
#define llong long long
#define pb(a) push_back(a)
#define INF 1000000007
using namespace std;
typedef pair<int, int> P;
typedef pair<llong, llong> LP;
typedef pair<int, P> PP;
typedef pair<llong, LP> LPP;
typedef long long int ll;
typedef pair<ll,int> LL_IP;
#define ARRAY_MAX 105
#define MOD 1000000007
ll cnt[ARRAY_MAX];
typedef struct edge{
int to;
int cost;
}EDGE;
void dijkstra(int n,vector<vector<EDGE> >& G,int x,vector<ll>& d){
/*頂点の個数、辺の情報、始点となる頂点、直前の頂点の情報、最短距離の情報*/
/*最終的にdは経由点からの最短距離が格納される、その過程では暫定的な最短距離が格納され、最短距離が見つかれば、その都度更新される*/
//vector<ll> d(n,INF);/*最終的な最短距離を保持、初期化はINF*/
d[x] = 0;
priority_queue<LL_IP,vector<LL_IP>,greater<LL_IP> > que;/*vectorのpriority_queueで暫定的な最短距離が小さい順に取り出す*/
que.push(LL_IP(0,x));/*経由点からダイクストラを適用するので経由点の暫定的な最短距離のコストは0*/
cnt[x] = 1;
while(!que.empty()){/*queが空になれば最短距離が全て探索できたことになる*/
LL_IP p = que.top();/*最短距離の1番小さいものの取り出し*/
que.pop();/*取り出したので調べたとみなし、queから出す*/
int v = p.second;/*取り出した頂点の番号*/
if(d[v] < p.first){
/*取り出した頂点からの最短距離よりも短い経路があるので更新の必要はない*/
continue;
}
for(int i = 0;i < G[v].size(); i++){
/*取り出した頂点から辺でつながっている頂点への最短距離を調べて現在の値より短ければ更新する*/
EDGE e = G[v][i];/*取り出した頂点からつながっている頂点を1つ取り出す*/
if(d[e.to] > d[v] + e.cost){
/*現在の最短距離よりも、現在の頂点を経由する経路のほうが最短距離が短い場合は最短距離を更新し、次の頂点を調べる*/
d[e.to] = d[v] + e.cost;/*最短経路の更新*/
que.push(P(d[e.to],e.to));/*先の頂点を調べるためqueに格納*/
cnt[e.to] = cnt[v];
}else if(d[e.to] == d[v] + e.cost){
cnt[e.to] = (cnt[e.to] + cnt[v])%MOD;
}
}
}
}
int main(){
int n,a,b,m;
cin >> n >> a >> b >> m;
//cout << n << a << b << m << endl;
a--;
b--;
vector<vector<EDGE> > G(n);/*n個の各頂点からそれ以外の頂点へのコスト*/
vector<ll> d(n,INF);/*最短経路*/
REP(i,m){
int x,y;
cin >> x >> y;
x--;
y--;/*配列の添え字へ合わせる*/
EDGE e1 = {y,1};
EDGE e2 = {x,1};
/*無効グラフなので双方向にコストを保持*/
G[x].pb(e1);/*頂点aから頂点bへのコストがc*/
G[y].pb(e2);/*頂点bから頂点aへのコストがc*/
}
/*辺の張り終わり*/
dijkstra(n,G,a,d);/*経由点から各頂点への最短距離を格納した配列*/
cout << cnt[b] << endl;
return 0;
}
Submission Info
Submission Time |
|
Task |
C - 正直者の高橋くん |
User |
punipuni |
Language |
C++14 (GCC 5.4.1) |
Score |
100 |
Code Size |
3872 Byte |
Status |
AC |
Exec Time |
1 ms |
Memory |
256 KB |
Judge Result
Set Name |
Sample |
All |
Score / Max Score |
0 / 0 |
100 / 100 |
Status |
|
|
Set Name |
Test Cases |
Sample |
subtask0_sample_01.txt, subtask0_sample_02.txt |
All |
subtask0_sample_01.txt, subtask0_sample_02.txt, subtask1_01.txt, subtask1_02.txt, subtask1_03.txt, subtask1_04.txt, subtask1_05.txt, subtask1_06.txt, subtask1_07.txt, subtask1_08.txt, subtask1_09.txt, subtask1_10.txt, subtask1_11.txt, subtask1_12.txt, subtask1_13.txt, subtask1_14.txt, subtask1_15.txt, subtask1_16.txt, subtask1_17.txt, subtask1_18.txt, subtask1_19.txt, subtask1_20.txt, subtask1_21.txt, subtask1_22.txt, subtask1_23.txt, subtask1_24.txt, subtask1_25.txt, subtask1_26.txt, subtask1_27.txt, subtask1_28.txt, subtask1_29.txt, subtask1_30.txt |
Case Name |
Status |
Exec Time |
Memory |
subtask0_sample_01.txt |
AC |
1 ms |
256 KB |
subtask0_sample_02.txt |
AC |
1 ms |
256 KB |
subtask1_01.txt |
AC |
1 ms |
256 KB |
subtask1_02.txt |
AC |
1 ms |
256 KB |
subtask1_03.txt |
AC |
1 ms |
256 KB |
subtask1_04.txt |
AC |
1 ms |
256 KB |
subtask1_05.txt |
AC |
1 ms |
256 KB |
subtask1_06.txt |
AC |
1 ms |
256 KB |
subtask1_07.txt |
AC |
1 ms |
256 KB |
subtask1_08.txt |
AC |
1 ms |
256 KB |
subtask1_09.txt |
AC |
1 ms |
256 KB |
subtask1_10.txt |
AC |
1 ms |
256 KB |
subtask1_11.txt |
AC |
1 ms |
256 KB |
subtask1_12.txt |
AC |
1 ms |
256 KB |
subtask1_13.txt |
AC |
1 ms |
256 KB |
subtask1_14.txt |
AC |
1 ms |
256 KB |
subtask1_15.txt |
AC |
1 ms |
256 KB |
subtask1_16.txt |
AC |
1 ms |
256 KB |
subtask1_17.txt |
AC |
1 ms |
256 KB |
subtask1_18.txt |
AC |
1 ms |
256 KB |
subtask1_19.txt |
AC |
1 ms |
256 KB |
subtask1_20.txt |
AC |
1 ms |
256 KB |
subtask1_21.txt |
AC |
1 ms |
256 KB |
subtask1_22.txt |
AC |
1 ms |
256 KB |
subtask1_23.txt |
AC |
1 ms |
256 KB |
subtask1_24.txt |
AC |
1 ms |
256 KB |
subtask1_25.txt |
AC |
1 ms |
256 KB |
subtask1_26.txt |
AC |
1 ms |
256 KB |
subtask1_27.txt |
AC |
1 ms |
256 KB |
subtask1_28.txt |
AC |
1 ms |
256 KB |
subtask1_29.txt |
AC |
1 ms |
256 KB |
subtask1_30.txt |
AC |
1 ms |
256 KB |