Submission #1294605

#TimeUsernameProblemLanguageResultExecution timeMemory
1294605tudor_costinSails (IOI07_sails)C++20
40 / 100
1096 ms7336 KiB
#include <bits/stdc++.h> #define int long long using namespace std; const int Nmax=1e5+5; vector<int> poz[Nmax]; pair<int,int> a[Nmax]; signed main() { int n; cin>>n; int maxi=0; for(int i=1;i<=n;i++) { cin>>a[i].first>>a[i].second; } sort(a+1,a+n+1); for(int i=1;i<=n;i++) { int h=a[i].first,k=a[i].second; if(h!=a[i-1].first) { for(int j=a[i-1].first+1;j<=h;j++) poz[0].push_back(j); } vector<pair<int,int>> chpoz; for(int cnt=0;cnt<=maxi;cnt++) { while(!poz[cnt].empty() && k>0) { int x=poz[cnt].back(); chpoz.push_back({x,cnt}); poz[cnt].pop_back(); k--; } poz[cnt].shrink_to_fit(); } for(auto [x,cnt]:chpoz) { poz[cnt+1].push_back(x); maxi=max(maxi,cnt+1); } } int ans=0; for(int cnt=0;cnt<=maxi;cnt++) { int nums=poz[cnt].size(); ans+=nums*cnt*(cnt-1)/2; } cout<<ans<<'\n'; 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...