Submission #799396

#TimeUsernameProblemLanguageResultExecution timeMemory
799396BidoTeimaSticks (POI11_pat)C++17
28 / 100
426 ms36352 KiB
#include <bits/stdc++.h> typedef long long ll; using namespace std; const int N = 1e6 + 3; vector<int>mn,mx; vector<short>color; ll st[2 * N]; void build(int l, int r, int node){ if(l == r){ st[node] = 1ll<<color[l]; return; } int mid = (l + r) >> 1; build(l, mid, node + 1); build(mid + 1, r, node + 2 * (mid - l + 1)); st[node] = st[node + 1] | st[node + 2 * (mid - l + 1)]; } ll query(int ql, int qr, int l, int r, int node){ if(l > qr || r < ql) return 0; if(ql <= l && r <= qr){ return st[node]; } int mid = (l + r) >> 1; return query(ql, qr, l, mid, node + 1) | query(ql, qr, mid + 1, r, node + 2 * (mid - l + 1)); } int main() { int k; cin>>k; vector<pair<int,short>>arr; for(int i = 0; i < k; i++){ int n; cin>>n; for(int j = 0; j < n; j++){ int w; cin>>w; arr.push_back(make_pair(w, i)); } } sort(arr.begin(), arr.end()); int curmn=arr[0].first,curmx=arr[0].first,curc=arr[0].second; for(int i = 1; i < (int)arr.size(); i++){ if(arr[i].second != arr[i - 1].second){ mn.push_back(curmn); mx.push_back(curmx); color.push_back(curc); curmn=curmx=arr[i].first,curc=arr[i].second; } } mn.push_back(curmn); mx.push_back(curmx); color.push_back(curc); int n = (int)color.size(); build(0, n - 1, 0); arr.clear(); int r = 2; for(int i = 0; i + 2 < n; i++){ if(__builtin_popcountll(query(i, n - 1, 0, n - 1, 0)) < 3)break; while(__builtin_popcountll(query(i, r, 0, n - 1, 0)) < 3){ r++; } assert(mx[i]<=mx[i+1]&&mx[i+1]<=mn[r]); //i,i+1,r if(mx[i]+mx[i+1]>mn[r]){ return cout<<color[i]+1<<' '<<mx[i]<<' '<<color[i+1]+1<<' '<<mx[i+1]<<' '<<color[r]+1<<' '<<mn[r], 0; } } cout<<"NIE"; return 0; }
#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...
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...