博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LightOJ 1079 Just another Robbery
阅读量:6156 次
发布时间:2019-06-21

本文共 1418 字,大约阅读时间需要 4 分钟。

抢银行,不能高于一个概率p,一共有n个银行。下面是存款+被抓概率;

dp[i][j]表示第i个银行之前,抢到j元的最大逃脱概率。

v[i]是概率,w[i]是钱数;

每次留下w[i]的空间,由之前的那个状态到这个状态(抢这个银行),又因为独立,所以就乘以概率就行;

dp[i][j]=max(dp[i-1][j],dp[i-1][j-w[i]]*(1-v[i]));

#include <iostream>

#include <functional>
#include <algorithm>
#include <complex>
#include <cstdlib>
#include <cstring>
#include <fstream>
#include <iomanip>
#include <sstream>
#include <utility>
#include <bitset>
#include <cctype>
#include <cstdio>
#include <limits>
#include <memory>
#include <string>
#include <vector>
#include <cmath>
#include <ctime>
#include <queue>
#include <stack>
#include <list>
#include <map>
#include <set>
using namespace std;
double dp[10000];
double v[10000];
int w[10000];
int main()
{
    int T,ncas=1;
    scanf ("%d",&T);
    while (T--)
    {
        memset(dp,0,sizeof(dp));
        memset(v,0,sizeof(v));
        memset(w,0,sizeof(w));
        double temp;
        int V=0,n;
        scanf ("%lf%d",&temp,&n);
        for (int i=1; i<=n; i++)
        {
            scanf ("%d%lf",&w[i],&v[i]);
//            cout<<"temp="<<temp*100.0<<endl;
            V+=w[i];
//            cout<<"v[i]="<<v[i]<<endl;
        }
//        cout<<V<<endl;
        int ans=0;
        dp[0]=1;
        for (int i=1; i<=n; i++)
        {
            for (int j=V; j>=w[i]; j--)
            {
                dp[j]=max(dp[j],dp[j-w[i]]*(1-v[i]));
//                printf ("dp[%d]=%d,",j,dp[j]);
            }
//            printf ("\n");
//            for (int j=0;j<=V;j++)
//            {
//                printf ("%d ",dp[j]);
//            }
//                printf ("\n");
        }
        int i;
        for (i=V;i>=0;i--) if (dp[i]>1-temp) break;
        printf ("Case %d: %d\n",ncas++,i);
    }
    return 0;
}

转载于:https://www.cnblogs.com/nj-czy/p/5440581.html

你可能感兴趣的文章
命令查询每个文件文件数
查看>>
《跟阿铭学Linux》第8章 文档的压缩与打包:课后习题与答案
查看>>
RAC表决磁盘管理和维护
查看>>
Apache通过mod_php5支持PHP
查看>>
发布一个TCP 吞吐性能测试小工具
查看>>
java学习:jdbc连接示例
查看>>
PHP执行批量mysql语句
查看>>
Extjs4.1.x 框架搭建 采用Application动态按需加载MVC各模块
查看>>
Silverlight 如何手动打包xap
查看>>
建筑电气暖通给排水协作流程
查看>>
JavaScript面向对象编程深入分析(2)
查看>>
linux 编码转换
查看>>
POJ-2287 Tian Ji -- The Horse Racing 贪心规则在动态规划中的应用 Or 纯贪心
查看>>
Windows8/Silverlight/WPF/WP7/HTML5周学习导读(1月7日-1月14日)
查看>>
关于C#导出 文本文件
查看>>
使用native 查询时,对特殊字符的处理。
查看>>
maclean liu的oracle学习经历--长篇连载
查看>>
ECSHOP调用指定分类的文章列表
查看>>
分享:动态库的链接和链接选项-L,-rpath-link,-rpath
查看>>
Javascript一些小细节
查看>>