제출 #1050072

#제출 시각아이디문제언어결과실행 시간메모리
1050072vjudge1Commuter Pass (JOI18_commuter_pass)C++17
15 / 100
242 ms35248 KiB
#pragma GCC optimize("O3") #pragma GCC target("avx2") #include <iostream> #include <vector> #include <algorithm> #include <cmath> #include <cstdlib> #include <time.h> #include <queue> #include <set> #include <map> #include <string> #include <unordered_map> #include <unordered_set> #include <bits/stdc++.h> #define speed ios_base::sync_with_stdio(0), cin.tie(0) #define TxtIO freopen("points.in","r",stdin); freopen("points.out","w",stdout); using namespace std; const int mod = 1e9+7; #define ll long long const int N=2e5+5; //mt19937_64 rng(chrono::steady_clock::now().time_since_epoch().count()); ll binpow (ll a, ll n) { ll res = 1; while (n) { if (n & 1) res = res * a % mod; a = a * a % mod; n >>= 1; } return res; } ll fct[103]; ll cnk(ll n,ll k){ return fct[n]*binpow(fct[k]*fct[n-k]%mod,mod-2)%mod; } void fcn(){ ll n,m,s,t,st,en; cin>>n>>m>>s>>t>>st>>en; vector <vector <pair <ll,ll> > > g(n+3); for (int i=0; i<m; i++){ ll x,y,c; cin>>x>>y>>c; g[x].push_back(make_pair(y,c)); g[y].push_back(make_pair(x,c)); } set <pair <ll,ll> > q; q.insert(make_pair(0,s)); vector <ll> var(n+3,1e18),d(n+3,1e18),p(n+3); var[s]=1; d[s]=0; while (!q.empty()){ ll v= (*q.begin()).second; q.erase(q.begin()); for (int i=0; i<g[v].size(); i++){ ll to=g[v][i].first,w=g[v][i].second; if (d[to]>d[v]+w){ var[to]=var[v]; p[to]=v; q.erase(make_pair(d[to],to)); d[to]=d[v]+w; q.insert(make_pair(d[to],to)); }else if(d[to]==d[v]+w){ var[to]++; } } } if (var[t]==1){ ll x=t; vector <vector <pair<ll,ll> > > g2 = g; while (x!=s){ g2[p[x]].push_back(make_pair(x,0)); g2[x].push_back(make_pair(p[x],0)); x=p[x]; } for (int i=0; i<=n; i++){ d[i]=1e18; } d[st]=0; q.clear(); q.insert(make_pair(0,st)); while (!q.empty()){ ll v=(*q.begin()).second; q.erase(q.begin()); for (int i=0; i<g2[v].size(); i++){ ll to=g2[v][i].first,w=g2[v][i].second; // cout<<v<<" "<<to<<" = "<<d[v]+w<<"\n"; if (d[to]>d[v]+w){ q.erase(make_pair(d[to],to)); d[to]=d[v]+w; q.insert(make_pair(d[to],to)); } } } cout<<d[en]<<"\n"; } } int main(){ //srand(time(0)); //fflush(stdout); // freopen("bridges.in","r",stdin); freopen("bridges.out","w",stdout); // speed; ll T=1; // cin>>T; for (int i=1; i<=T; i++){ fcn(); } } /* 1 2 3 4 5 6 7 */

컴파일 시 표준 에러 (stderr) 메시지

commuter_pass.cpp: In function 'void fcn()':
commuter_pass.cpp:69:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<long long int, long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   69 |   for (int i=0; i<g[v].size(); i++){
      |                 ~^~~~~~~~~~~~
commuter_pass.cpp:111:19: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<long long int, long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  111 |    for (int i=0; i<g2[v].size(); i++){
      |                  ~^~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...