This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
//JOI 2022 Final Round
#include<bits/stdc++.h>
using namespace std;
//#define double long double
const int N=505;
double dp[N][N][N];
const double INF=1e9+7;
void init(){
for(int i=0; i<N; i++){
for(int j=0; j<N; j++){
for(int k=0; k<N; k++){
dp[i][j][k] = INF;
}
}
}
}
signed main(){
ios_base::sync_with_stdio(false);
cin.tie(0);
int n, k;
cin >> n >> k;
vector<int> a(n);
vector<int> b(n);
for(int i=0; i<n; i++){
cin >> a[i] >> b[i];
}
vector<int> sorted(n);
iota(sorted.begin(), sorted.end(), 0);
sort(sorted.begin(), sorted.end(), [&](int i, int j){
if(b[i]==-1) return false;
if(b[j]==-1) return true;
return b[i]<b[j];
});
cout.precision(300);
init();
dp[0][0][0]=(double)0;
for(int i=0; i<n; i++){
int ind=sorted[i];
//cout << i << ": " << ind << "\n";
for(int x=0; x<=i+1; x++){
for(int y=0; y<=x; y++){
dp[i+1][x][y] = dp[i][x][y];
if(0<x){
dp[i+1][x][y] = min(dp[i+1][x][y], dp[i][x-1][y] + (double)a[ind]/(double)(y+1));
}
if(0<y && b[ind]!=-1){
dp[i+1][x][y] = min(dp[i+1][x][y], dp[i][x-1][y-1] + (double)b[ind]/(double)y);
//cout << dp[i][x-1][y-1] << "\n";
}
//cout << i << " " << x << " " << y << ": " << dp[i+1][x][y] << "\n";
}
}
}
double ans=INF;
for(int y=0; y<=n; y++){
ans = min(ans, dp[n][k][y]);
}
cout << ans << "\n";
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |