HDOJ 2955

2024-06-05 11:18
文章标签 hdoj 2955

本文主要是介绍HDOJ 2955,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这道背包题和我们常见的背包题有所不同。如果根据以前做背包的惯性思维和题中数据的迷惑,会把概率乘以100来当作容量。但是经测试是不行的。

我们不妨换种思路,看做DAG上的DP思想。将所有有可能达到的钱的最大“逃跑”概率算出来,最后再将能够达到的最大的钱输出。而能不能够达到这个可以将所有除0以外的值初始化为0.意为逃跑的概率为0。

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int main()
{
    //freopen("data.in","r",stdin);
    double dp[10005];
    int sum,n,t;
    double p,v[105];
    int c[105];
    int i,j,ret;
    scanf("%d",&t);
    while(t--)
    {
        sum=0;
        scanf("%lf%d",&p,&n);
        for(i=0;i<n;i++)
            scanf("%d%lf",&c[i],&v[i]);
        for(i=0;i<n;i++)
            sum+=c[i];
        for(i=0;i<n;i++) v[i]=1-v[i];
        dp[0]=1;
        for(i=1;i<=sum;i++) dp[i]=0;
        for(i=0;i<n;i++)
            for(j=sum;j>=c[i];j--)
            {
                if(dp[j]<=dp[j-c[i]]*v[i])
                {
                    dp[j]=dp[j-c[i]]*v[i];
                }
            }
        ret=-1;
        for(i=0;i<=sum;i++)
            if(dp[i]>=(1-p)) ret=i;
        printf("%d\n",ret);
    }
    return 0;
}

这篇关于HDOJ 2955的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1032902

相关文章

hdoj 2371 decoded string. Decode the Strings

http://acm.hdu.edu.cn/showproblem.php?pid=2371 题意:给出编码的原则,给一个字符串,输出该字符串经过m次解码后的字符串。 啊啊啊啊。。。。无耻的看错题意了,以为给出字符串输出经过m次解码的后的字符串,样例死活过不了,赛后才发现问的是“decoded string”. 即解码后的字符串。。 思路:对于 5 3 2 3 1 5 4 helol

HDU 2955 Robberies (转化概率-01背包)

【题目链接】:click here~~ 代码: /** Problem: HDU No.2955* Running time: 46MS* Complier: G++* Author: ACM_herongwei* Create Time: 15:01 2015/9/9 星期三* zeroonebags* 用成功逃走的概率当做价值!银行的总钱数当做背包容量!单个银行的钱数体积

HDOJ 1874 畅通工程续——结构体模拟邻接链表的SPFA算法

Problem Description 某省自从实行了很多年的畅通工程计划后,终于修建了很多路。不过路多了也不好,每次要从一个城镇到另一个城镇时,都有许多种道路方案可以选择,而某些方案要比另一些方案行走的距离要短很多。这让行人很困扰。 现在,已知起点和终点,请你计算出要从起点到终点,最短需要行走多少距离。   Input 本题目包含多组数据,请处理到文

poj 2955(区间DP)

Language:Default Brackets Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 2394   Accepted: 1233 Description We give the following inductive definition of a “regular bracke

九度OJ-1435-迷瘴(HDOJ-2570)

题目地址:点击打开链接 题目描述: 通过悬崖的yifenfei,又面临着幽谷的考验—— 幽谷周围瘴气弥漫,静的可怕,隐约可见地上堆满了骷髅。由于此处长年不见天日,导致空气中布满了毒素,一旦吸入体内,便会全身溃烂而死。 幸好yifenfei早有防备,提前备好了解药材料(各种浓度的万能药水)。现在只需按照配置成不同比例的浓度。 现已知yifenfei随身携带有n种浓度的万能药水,体积V都相

POJ 2955 区间DP

求最多能匹配的括号数*2 #include "stdio.h"#include "string.h"int max(int a,int b){if (a<b) return b;else return a;}int judge(char a,char b){if (a=='(' && b==')') return 1;if (a=='[' && b==']') return 1

HDU-2955 Robberies 01背包 + 概率

题目链接 刚开始以为概率就2位小数 乘100来做WA 看了讨论区恍然大悟。 用成功逃走的概率当做价值!银行的总钱数当做背包容量! #include <stdio.h>#include <string.h>#include <iostream>#include<functional>#include <queue>#include <string>#include

HDoj Integer Inquiry(大数)

真心要哭了。。这几天在搞大数  高精度计算  昨晚在机房敲 很快敲完了  就是过不了啊过不了  劳资都想骂脏话啊   NMB  一开始不输出前面的0啊 过不了  看discuss 百度 找了个AC的代码 找了几组测试数据  那个代码输出前面的0啊  我的妈  今天有找了个代码 不输出0啊 我的天。。。真心要被逼疯了  幸好还是AC了。。。算是有进步吧  之前的心态肯定坚持不下来啊

hdoj Least Common Multiple--最大公约数和最小公倍数

解题思路:求两个数的最小公倍数=两个数相乘,再处理最大公约数。最大公约数用辗转相除术。 最大公约数和最小公倍数说明见下面连接: https://jingyan.baidu.com/article/0964eca21e03ac8285f53602.html http://blog.csdn.net/qq_31828515/article/details/51812154 #include <

hdoj 1003 Max Sum---动态规划,最大子序列求和

初来乍到,动态规划不会呀,刚开始用暴力法,超时了!超时代码如下: 思路:大致是选中一个数当做结尾,然后加和。例如在6 -1 5 8 -7选中5作为结尾大致有如下序列 6  -1   5     -1   5           5 就这样遍历所以的结尾,结果超时。代码如下: #include<iostream>#include<algorithm>using namespace s