제출 #43440

#제출 시각아이디문제언어결과실행 시간메모리
43440duicemanPalembang Bridges (APIO15_bridge)C++14
0 / 100
5 ms3740 KiB
#include <bits/stdc++.h> using namespace std; #define x first #define y second #define umap unordered_map #define pqueue priority_queue #define mset multiset #define mp make_pair #define mt make_tuple #define all(x) x.begin(),x.end() #define long long long #define MOD 1000000007 #define MAX (long)(1e16+5) #define MIN (long)(-1e16-5) #define FILEIN_ freopen("__in.txt","r",stdin) #define FILEOUT_ freopen("__out.txt","w",stdout) #define FILEIO_ freopen("__in.txt","r",stdin),freopen("__out.txt","w",stdout) #define FILEIN(text) freopen(text,"r",stdin) #define FILEOUT(text) freopen(text,"w",stdout) #define FILEIO(text) freopen(text".in","r",stdin),freopen(text".out","w",stdout) char c1[5],c2[5]; umap<long,long> in,out; pair<long,long> a[100005]; main(){ long t,i,j,k,n,m,x,y,res=0,l=0,r=0,mn=MAX,p; set<long> pos; in.reserve(200005); out.reserve(200005); double med; scanf("%lld %lld",&m,&n); if(m != 1) return 136; for(i = 1; i <= n; i++){ scanf("%s %lld %s %lld",c1,&x,c2,&y); x++; y++; if(x > y) swap(x,y); res += y-x; if(c1[0] == c2[0]){ n--; i--; continue; } a[i] = {x,y}; med += (double)(x+y)/2.0; res++; in[x]++; out[y]++; pos.emplace(x); pos.emplace(y); } med /= (double)n; p = (long)med; l = r = 0; for(long x : pos){ res += x*2*in[x]; r += in[x]; } y = 0; for(long x : pos){ if(x >= max(p,1LL)) break; res -= (x-y)*r*2; res += (x-y)*l*2; r -= in[x]; l += out[x]; mn = min(mn,res); y = x; } // printf("%lld - %lld\n",max(p,1LL),min(p+1,(long)1e9+5)); for(x = max(p,1LL); x <= min(p+1,(long)1e9+5); x++){ res -= (x-y)*r*2; res += (x-y)*l*2; r -= in[x]; l += out[x]; mn = min(mn,res); y = x; } printf("%lld\n",mn); return 0; }

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

bridge.cpp:28:6: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type]
 main(){
      ^
bridge.cpp: In function 'int main()':
bridge.cpp:29:7: warning: unused variable 't' [-Wunused-variable]
  long t,i,j,k,n,m,x,y,res=0,l=0,r=0,mn=MAX,p;
       ^
bridge.cpp:29:11: warning: unused variable 'j' [-Wunused-variable]
  long t,i,j,k,n,m,x,y,res=0,l=0,r=0,mn=MAX,p;
           ^
bridge.cpp:29:13: warning: unused variable 'k' [-Wunused-variable]
  long t,i,j,k,n,m,x,y,res=0,l=0,r=0,mn=MAX,p;
             ^
bridge.cpp:35:26: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%lld %lld",&m,&n);
                          ^
bridge.cpp:38:39: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%s %lld %s %lld",c1,&x,c2,&y);
                                       ^
bridge.cpp:56:18: warning: 'med' may be used uninitialized in this function [-Wmaybe-uninitialized]
  med /= (double)n;
                  ^
#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...