博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
10934 - Dropping water balloons(DP)
阅读量:5290 次
发布时间:2019-06-14

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

这道题的思路非常难想。 问你须要的最少实验次数,这是非常难求解的。并且我们知道的条件仅仅有三个。k、n、实验次数 。

所以我们最好还是改变思路,转而求最高所能确定的楼层数 。  那么用d[i][j]表示用i个球,实验j次所能确定的最高楼层数 。

那么我们如果第j次实验是在k楼,有两种可能: 1、球破了。那么状态怎样转移? 用了一个球,用了一次实验机会。所以最优情况一定是从d[i-1][j-1]转移过来的,所以这一次实验向下所能确定的最大楼层数为d[i-1][j-1] + 1 ;2、球没有破。那么代价仅仅是用掉了一次实验机会,所以向上最高仍能确定d[i][j-1]层 。

这样d[i][j]就成功的将状态转移到子状态的最优解上了 。  那么这将也是最优解,由于他们具有相似的结构 。

代码例如以下:

#include
using namespace std;unsigned long long k,n,d[105][65];int main() { while(cin>>k>>n&&k) { memset(d,0,sizeof(d)); for(int i=1;i<=k;i++) { for(int j=1;j<=64;j++) { d[i][j] = d[i-1][j-1] + 1 + d[i][j-1]; } } int ans = 0; for(int i=64;i>=1;i--) {//搜索最少实验次数。假设64满足条件。则超过了实验次数限制 if(d[k][i] < n) { ans = i+1; break; } if(d[k][i] == n) { ans = i; break; } } if(ans<=63) printf("%d\n",ans); else printf("More than 63 trials needed.\n"); } return 0;}

转载于:https://www.cnblogs.com/gcczhongduan/p/5270165.html

你可能感兴趣的文章
归并排序的进一步理解
查看>>
C - Wooden Sticks
查看>>
Spring boot中普通工具类不能使用@Value注入yml文件中的自定义参数的问题
查看>>
[8.3] Magic Index
查看>>
(转·)WMPLib
查看>>
C语言结构体对齐
查看>>
跨应用Session共享
查看>>
Vue动态路由
查看>>
电脑小窍门
查看>>
IDEA环境设置
查看>>
Oracle行列转换小结
查看>>
W-D-S-链接地址
查看>>
3、图片处理
查看>>
HTML-日记3
查看>>
java enum 用法
查看>>
java常见文件操作
查看>>
python虚拟环境的安装和配置
查看>>
在eclipse中添加和删除项目
查看>>
Search a 2D Matrix & II
查看>>
网站更新后客户端缓存问题
查看>>