제출 #387812

#제출 시각아이디문제언어결과실행 시간메모리
387812RohamIzadidoost즐거운 행로 (APIO20_fun)C++14
0 / 100
25 ms37868 KiB
#pragma GCC optimize("Ofast,unroll-loops,fast-math") //#include "fun.h" #include<bits/stdc++.h> using namespace std; typedef long long ll ; #define pll pair<ll , ll > #define all(x) (x).begin(),(x).end() #define SZ(x) (ll)(x).size() #define X first #define Y second #define mp make_pair #define pii pair<int , int> #define vec vector #define file_io freopen("input.txt", "r", stdin);freopen("output.txt", "w", stdout); #define migmig ios::sync_with_stdio(false);cin.tie(0);cout.tie(0); #define pb push_back // BIG p : 1000000000000037 , 100000000003 ll poww(ll a, ll b, ll md) { return (!b ? 1 : (b & 1 ? a * poww(a * a % md, b / 2, md) % md : poww(a * a % md, b / 2, md) % md)); } const int maxn = 2000*100+5 ; const ll inf = 9223372036854775807 ; const ll mod = 1e9 + 7 ; const int lg = 20 ; pii p ; int cur , mark[maxn] , n , H[4 * maxn] , val[4 * maxn] , X , pt; set<pii> seg[4 * maxn] ; void build(int x = 0 , int lx = 0 , int rx = pt , int h = 0 ){ if(rx - lx == 1 && lx < n ){ seg[x].insert({-1 * h , x}) ; H[x] = h ; val[x] = lx ; return ; }else if(rx - lx == 1)return ; int mid = lx + rx >> 1 ; build(x * 2 + 1, lx , mid , h + 1) ; build(x * 2 + 2 , mid , rx , h + 1) ; seg[x] = seg[x * 2 + 1] ; for(auto u : seg[x * 2 + 2]) seg[x].insert(u) ; // sort(all(seg[x])) ; } void del(int x){ seg[x].erase({-H[X] , X}) ; if(x == 0) return ; x = (x - 1) / 2 ; del(x) ; } pii dfs(int v){ int x , V = v ;; p = {0 , 0} ; while(v != 0){ x = v ; v = (v - 1) / 2 ; if(x & 1) x = v << 1 ; else x = v << 1 | 1 ; if(SZ(seg[x])) p = max(p ,{ H[V] + -1 * (seg[x].begin() -> X) - 2 * H[v] , seg[x].begin() -> Y } ) ; } return p ; } vec<int> ans ; vec<int> createFunTour(int N , int Q){ n = N ; pt = 1 ; while(pt < n ) pt *= 2 ; build() ; ans.pb(seg[1].begin() -> Y) ; while(SZ(ans) < n){ //cout<<SZ(ans) <<" : " << ans.back() << " -> " << val[ans.back()] << endl ; X = ans.back() ; del(ans.back()) ; ans.pb(dfs(ans.back()).Y) ; } for(int i = 0 ; i < n ; i ++ ) ans[i] = val[ans[i]] ; return ans ; } /*int main() { migmig ; cin>>n ; pt = 1 ; while(pt < n ) pt *= 2 ; build() ; ans.pb(seg[1].begin() -> Y) ; while(SZ(ans) < n){ //cout<<SZ(ans) <<" : " << ans.back() << " -> " << val[ans.back()] << endl ; X = ans.back() ; del(ans.back()) ; ans.pb(dfs(ans.back()).Y) ; } for(int i = 0 ; i < n ; i ++ ) ans[i] = val[ans[i]] ; for(auto u : ans) cout<<u <<" " ; }*/

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

fun.cpp: In function 'void build(int, int, int, int)':
fun.cpp:35:15: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
   35 |  int mid = lx + rx >> 1 ;
      |            ~~~^~~~
#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...