Submission #638710

#TimeUsernameProblemLanguageResultExecution timeMemory
638710jamezzzLet's Win the Election (JOI22_ho_t3)C++17
10 / 100
891 ms4300 KiB
#include <bits/stdc++.h> using namespace std; #define pf printf #define sf scanf typedef long long ll; typedef long double ld; typedef pair<int,int> ii; #define maxn 505 #define INF 1023456789 int n,k,a[maxn],b[maxn]; vector<ii> v; ld memo[maxn][maxn]; int main(){ sf("%d%d",&n,&k); for(int i=0;i<n;++i){ int x,y; sf("%d%d",&x,&y); if(y==-1)y=INF; v.push_back({y,x}); } sort(v.begin(),v.end()); for(int i=0;i<n;++i){ tie(b[i],a[i])=v[i]; } for(int i=0;i<=n+1;++i){ for(int j=0;j<=n+1;++j){ memo[i][j]=INF; } } memo[0][0]=0; for(int pos=0;pos<n;++pos){ for(int ppl=n;ppl>=0;--ppl){ for(int vote=n;vote>=0;--vote){ ld ans=memo[ppl][vote]; if(vote!=0)ans=min(ans,memo[ppl][vote-1]+(ld)a[pos]/(ppl+1)); if(vote!=0&&ppl!=0&&b[pos]<=1000){ ans=min(ans,memo[ppl-1][vote-1]+(ld)b[pos]/ppl); } memo[ppl][vote]=ans; } } } ld ans=INF; for(int i=0;i<=n;++i)ans=min(ans,memo[i][k]); pf("%Lf\n",ans); }

Compilation message (stderr)

Main.cpp: In function 'int main()':
Main.cpp:18:4: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   18 |  sf("%d%d",&n,&k);
      |    ^
Main.cpp:21:5: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   21 |   sf("%d%d",&x,&y);
      |     ^
#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...