제출 #109557

#제출 시각아이디문제언어결과실행 시간메모리
109557nvmdava마상시합 토너먼트 (IOI12_tournament)C++17
0 / 100
202 ms3368 KiB
#include <bits/stdc++.h> using namespace std; #define BIG 131072 int fen[BIG]; int in[BIG]; int p[BIG]; int last[BIG]; int ans[BIG]; int find(int v){ return in[v] == 1 ? v : p[v] = find(p[v]); } void upd(int loc){ while(loc < BIG){ fen[loc]++; loc += loc & -loc; } } int sum(int loc){ int res = 0; while(loc){ res += fen[loc]; loc -= loc & -loc; } return res; } void rangeupd(int l, int r){ while((l = find(p[l])) <= r){ in[l] = 0; upd(l); } } int finder(int val){ int res = 0; int id = 0; for(int i = 16; i >= 0; i--){ if(res + fen[id + (1 << i)] <= val){ id += 1 << i; res += fen[id]; } } return id; } int GetBestPosition(int N, int C, int R, int *K, int *S, int *E) { for(int i = 1; i <= N; i++){ p[i] = i + 1; in[i] = 1; } for(int i = 1; i < BIG; i++){ fen[i] = i & -i; } for(int i = 0; i < N - 1; i++){ last[i + 1] = last[i]; if(K[i] > R) last[i + 1] = i + 1; } last[N] = last[N - 1]; for(int i = 0; i < C; i++){ S[i] = finder(S[i] + 1); E[i] = find(p[finder(E[i] + 1)]) - 1; cerr<<S[i]<<' '<<E[i]<<'\n'; rangeupd(S[i], E[i]); if(last[E[i] - 1] < S[i]){ ans[S[i]]++; ans[E[i] + 1]--; } } int ret = 1; for(int i = 1; i <= BIG; i++){ ans[i] += ans[i - 1]; if(ans[i] > ans[ret]) ret = i; } return ret - 1; }

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

tournament.cpp: In function 'int GetBestPosition(int, int, int, int*, int*, int*)':
tournament.cpp:76:16: warning: iteration 131071 invokes undefined behavior [-Waggressive-loop-optimizations]
         ans[i] += ans[i - 1];
         ~~~~~~~^~~~~~~~~~~~~
tournament.cpp:75:22: note: within this loop
     for(int i = 1; i <= BIG; i++){
                      ^
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...