Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 10672 Accepted Submission(s): 4019
后面的m行,每行都有两个数据ai(整型),bi(实型)分别表示第i个学校的申请费用和可能拿到offer的概率。
输入的最后有两个0。
思路:本题相当于求他不被录取的最小概率。
dp[j]=min(dp[j+d[i].m]*d[i].x,dp[j]);就是在花费剩余j时不被录取的最小概率。
#include<iostream> #include<iomanip> #include<algorithm> using namespace std; const int mm=10010; const float smin=0.000001; bool vis[mm]; float dp[mm]; class node { public: int m; float x; }d[mm]; int main() { int n,cost; while(cin>>cost>>n) { if(cost==0&&n==0)break; for(int i=0;i<n;i++) { cin>>d[i].m>>d[i].x; d[i].x=1-d[i].x; } dp[cost]=1.0; float ans=1; for(int i=0;i<n;i++) { for(int j=0;j<=cost-d[i].m;j++) { if(dp[j]>smin) dp[j]=min(dp[j+d[i].m]*d[i].x,dp[j]); else dp[j]=dp[j+d[i].m]*d[i].x; if(dp[j]>smin&&dp[j]<ans)ans=dp[j]; } } ans=1-ans;ans*=100; cout.setf(ios::fixed); cout<<setprecision(1)<<ans<<"%"<<"\n"; } }