Submission #1251255

#TimeUsernameProblemLanguageResultExecution timeMemory
1251255guymmkTriple Peaks (IOI25_triples)C++20
11.68 / 100
109 ms21340 KiB
// Source: https://usaco.guide/general/io #include <bits/stdc++.h> #include "triples.h" using namespace std; vector<int> v; int n; set<vector<int>>s; void is_triple(vector<int>g){ sort(g.begin(),g.end()); if(g[0]==g[1]||g[0]==g[2]||g[1]==g[2]||g[0]<0||g[2]>=n)return; vector<int>a,b; a={g[1]-g[0],g[2]-g[0],g[2]-g[1]}; b={v[g[0]],v[g[1]],v[g[2]]}; sort(a.begin(),a.end()); sort(b.begin(),b.end()); if(a==b)s.insert(g); } long long count_triples(vector<int> hsh) { v=hsh; s.clear(); int ans=0; n=v.size(); for(int i=0;i<n;i++){ int l=i-v[i],r=i+v[i]; is_triple({i,r,r+v[i]}); is_triple({i,l,l-v[i]}); if(r<n){ is_triple({i,r,r-v[r]}); is_triple({i,r,i+v[r]}); } if(l>=0){ is_triple({i,l,l+v[l]}); is_triple({i,l,i-v[l]}); } }return s.size(); } vector<int> construct_range(int M, int K) { vector<int>v; for(int i=1;i<=M/2;i++){ v.push_back(i); v.push_back(i); }return v; }
#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...