Submission #970658

#TimeUsernameProblemLanguageResultExecution timeMemory
970658PenguinsAreCutePassport (JOI23_passport)C++17
100 / 100
932 ms121164 KiB
#include <bits/stdc++.h> using namespace std; #define int long long //#define hello cout<<"line "<<__LINE__<<endl; #define hello 69 using ii = pair<int,int>; vector<ii> adj[400005]; void bfs(int s, int dist[]) { dist[s] = 0; priority_queue<ii,vector<ii>,greater<ii>> pq; for(pq.push({0,s});pq.size();) { auto [d,x] = pq.top(); pq.pop(); if(d!=dist[x]) continue; for(auto [i,di]: adj[x]) if(dist[i]>d+di) { dist[i] = d+di; pq.push({d+di,i}); } } } main() { int n; cin >> n; int l[n], r[n]; for(int i=0;i<n;i++) {cin>>l[i]>>r[i]; l[i]--;} for(int i=1;i<n;i++) {adj[i<<1].push_back({i,0}); adj[i<<1|1].push_back({i,0});} for(int i=0;i<n;i++) { for(int ll=l[i]+n,rr=r[i]+n;ll<rr;ll>>=1,rr>>=1) { if(ll&1) adj[ll++].push_back({i+n,1}); if(rr&1) adj[--rr].push_back({i+n,1}); } } int dista[2*n], distb[2*n], distt[2*n+5]; fill(dista,dista+2*n,12102010); fill(distb,distb+2*n,12102010); fill(distt,distt+2*n+5,12102010); bfs(n,dista); bfs(2*n-1,distb); //for(int i=1;i<2*n;i++) printf("dista[%lld]=%lld\n",i,dista[i]); //for(int i=1;i<2*n;i++) printf("distb[%lld]=%lld\n",i,distb[i]); for(int i=0;i<n;i++) adj[2*n].push_back({i+n,max(dista[i+n],1LL)+max(distb[i+n],1LL)}); bfs(2*n,distt); int q; cin >> q; for(int x;q--;) { cin >> x; cout << (distt[x+n-1]==12102010?-1:distt[x+n-1]-1) << "\n"; } }

Compilation message (stderr)

passport.cpp:20:1: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type]
   20 | main() {
      | ^~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...