제출 #27076

#제출 시각아이디문제언어결과실행 시간메모리
27076noobprogrammerBulldozer (JOI17_bulldozer)C++14
20 / 100
2028 ms31848 KiB
#include <bits/stdc++.h> using namespace std ; #define ii pair<int,int> #define fi first #define se second #define vi vector<int> #define vii vector<ii> typedef long long ll ; int n , w[2010] , pos[2010] , sz = 0 ; ll st[10010] , L[10010] , R[10010] , sum[10010] , res = 0 ; ii pnt[2010], cur ; pair<ii,int> arr[2010] ; pair<ii,ii> srt[4000010] ; vector< pair<ii,int> > tmp ; int gcd(int x,int y){ if(y == 0) return x ; return gcd(y , x%y ); } bool slpcmp(ii x, ii y){ if( x.fi == 0 ) return 1 ; if( y.fi == 0 ) return 0 ; if( x.se == 0 && y.se == 0) return 0 ; if( x.se == 0 ){ if(y.se > 0 )return 1 ; else return 0 ; } if(y.se == 0){ if(x.se > 0) return 0 ; else return 1 ; } if( (x.se<0 && y.se<0) || (x.se>0 && y.se>0 ) ) return (double)x.fi/(double)x.se > (double)y.fi/(double)y.se ; return (double)x.fi / (double)x.se < (double)y.fi / (double)y.se ; } bool cmp(pair<ii,ii> x , pair<ii,ii> y){ return slpcmp(x.fi , y.fi) ; } bool pntcmp(pair<ii,int> x , pair<ii,int> y){ ll x1 = 1LL * cur.se * x.fi.se - 1LL * cur.fi * x.fi.fi ; ll x2 = 1LL * cur.se * y.fi.se - 1LL * cur.fi * y.fi.fi ; if(x1 == x2) return x.fi.se > y.fi.se ; return x1 > x2 ; } bool ycmp(pair<ii,int> x , pair<ii,int> y){ if(x.fi.se == y.fi.se) return x.fi.fi < y.fi.fi ; return x.fi.se < y.fi.se ; } void upd(int node, int f , int l ,int x , ll cst){ if(f == l){ sum[node] = st[node] = cst ; L[node] = max(0LL , cst) ; R[node] = max(0LL , cst) ; return ; } int mid = (f+l)>>1 ; if(x > mid) upd(2*node+1 , mid+1 , l , x, cst) ; else upd(2*node , f, mid , x ,cst) ; st[node] = max(st[2*node] , st[2*node+1] ) ; sum[node] = sum[2*node] + sum[2*node+1] ; L[node] = max(sum[2*node] + L[2*node+1] , L[2*node] ) ; R[node] = max(sum[2*node+1] + R[2*node] , R[2*node+1] ) ; st[node] = max(st[node] , L[2*node+1] + R[2*node] ) ; } int main(){ // freopen("in.txt" , "r" , stdin ) ; // freopen("out.txt" , "w" , stdout) ; scanf("%d",&n) ; int a , b , c ; ii p1, p2 ; for(int i=1;i<=n;i++){ scanf("%d%d%d",&a,&b,&c) ; pnt[i] = {a,b} ; w[i] = c ; for(int j=1;j<i;j++){ p1 = pnt[i] ; p2 = pnt[j] ; a = p1.se - p2.se ; b = p1.fi-p2.fi ; c = gcd(abs(a) , abs(b)) ; a/=c; b/=c ; if( a < 0 ) b = -b , a = -a ; srt[sz] = { {a , b} , {i , j} } ; sz++ ; } arr[i] = { pnt[i] , i } ; } // return 0 ; sort( srt , srt + sz , cmp ) ; int j = 0, v ; ll qs = 0 , mn = 0 ; sort(arr +1 , arr+n+1 , ycmp ) ; // slope = 0 case for(int i=1;i<=n;){ j = i ; while(arr[i].fi.se == arr[j].fi.se && j<=n ) { // printf("---> %d : %d %d \n", j , arr[j].fi.fi , arr[j].fi.se ) ; qs += (ll)w[ arr[j].se ]; pos[arr[j].se] = j ; j++ ; } res = max(res , qs - mn) ; mn = min(mn ,qs) ; i = j; } // printf("mid : %lld\n ", res) ; for(int i=1;i<=n;i++) upd(1 , 1 , n , pos[i] , w[i] ) ; j = 0 ; res = max(res , st[1]) ; while(srt[j].fi.fi == 0 && j<sz ) j++ ; // slope != 0 case pair<ii,int> x , y ; int f , l ; ll W ; for(int i=j ; i<sz ; ){ // printf("\n%d : %d %d %lld \n" , i , srt[i].fi.fi , srt[i].fi.se , res ) ; j = i ; cur = srt[i].fi ; tmp.clear() ; while(srt[j].fi == cur && j<sz ) { v = srt[j].se.fi ; tmp.push_back({ pnt[v] , srt[j].se.fi}) ; v = srt[j].se.se ; tmp.push_back({ pnt[v] , srt[j].se.se}) ; j++ ; } sort( tmp.begin() , tmp.end() , pntcmp ) ; tmp.resize(unique(tmp.begin() , tmp.end() ) - tmp.begin() ) ; i = j ; for(int k=0;k<tmp.size();){ j = k ; f = 1e9 , l = 0 ; W = 0 ; x = tmp[k] , y = tmp[j] ; ll x1 = 1LL * cur.se * x.fi.se - 1LL * cur.fi * x.fi.fi ; ll x2 = 1LL * cur.se * y.fi.se - 1LL * cur.fi * y.fi.fi ; while(x2 == x1 && j<tmp.size()){ y = tmp[j] ; f = min(pos[y.se] , f) ; l = max(pos[y.se] , l) ; x2 = 1LL * cur.se * y.fi.se - 1LL * cur.fi * y.fi.fi ; // upd segtree ; upd(1 , 1 , n , pos[y.se] , 0 ) ; // combine points ; W += (ll)w[y.se] ; // printf("%d : %d %d %d %d %d %d %d\n", j , y.fi.fi , y.fi.se , y.se , pos[y.se] , W , f , l) ; j++ ; if(j >= tmp.size()) break ; y = tmp[j] ; x2 = 1LL * cur.se * y.fi.se - 1LL * cur.fi * y.fi.fi ; } sort( arr+f , arr+l+1 , pntcmp ) ; // upd at f with W ; upd(1 , 1, n, f , W ) ; // printf("---> %d %d\n" , f, l ) ; for(int ptr=f;ptr<=l;ptr++) pos[arr[ptr].se] = ptr ; k = j ; } // find res res = max(res , st[1]) ; // upd again for(int k=0;k<tmp.size();k++){ // upd at new pos ; v = tmp[k].se ; upd( 1 , 1 , n , pos[v] , w[v] ) ; } res = max(res , st[1]) ; } printf("%lld\n", res) ; }

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

bulldozer.cpp: In function 'int main()':
bulldozer.cpp:141:16: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
   for(int k=0;k<tmp.size();){
               ~^~~~~~~~~~~
bulldozer.cpp:148:23: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
    while(x2 == x1 && j<tmp.size()){
                      ~^~~~~~~~~~~
bulldozer.cpp:159:10: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
     if(j >= tmp.size()) break ;
        ~~^~~~~~~~~~~~~
bulldozer.cpp:175:16: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
   for(int k=0;k<tmp.size();k++){
               ~^~~~~~~~~~~
bulldozer.cpp:78:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d",&n) ;
  ~~~~~^~~~~~~~~
bulldozer.cpp:82:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d%d%d",&a,&b,&c) ;
   ~~~~~^~~~~~~~~~~~~~~~~~~
#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...