【Uva 10934】Dropping water balloons
【Link】:
【Description】
等价题意:
某人在1..n内选一个数x;
然后让你去猜;
你可以问他是不是在哪个范围里;
每次会告诉你YES或者NO;
问你在最坏的情况下猜出答案需要猜多少次;
且猜的数字大于x的次数不能超过k次.
【Solution】
动态规划.
设f[i][j]表示前i个水球,做了j次试验;能得到的最大高度;
这里的f[i][j];
指的是,如果问的数字是1..f[i][j],的话,用i个水球都能够通过试验猜到.
(这里的状态f[i][j]中,j>=i也是可行的状态的..)
考虑第一次试验;
假设从高度x落下;
则
1.如果水球破了
则要保证如果问的数字是1..x-1的话,用i-1个球和j-1次试验能猜得到.
那么,x的最大值应该是f[i-1][j-1]+1;
2.如果水球没破
则我们还剩下i个球以及j-1次试验的机会;
而x的最大值只能是f[i-1][j-1]+1
(这里,我们必须也要照顾到球破了的情况才行..因为是最坏情况)
所以,如果在球没破的时候,我们最多能够处理
x+f[i][j-1]也即1..f[i-1][j-1]+1+f[i][j-1]
这样就能得到状态转移方程了;
f[i][j] = f[i-1][j-1]+1+f[i][j-1]
这样如果想的数字在1..f[i][j]这个范围内都能保证猜得到.
然后在f[k][j],j∈[1..63]中找最小的满足f[k][j]>=n的j;
输出就好;
如果没找到,就输出无解;
UPD1
对转移方程的解释:
这里如果球破了的话,1..f[i-1][j-1]能得到;
球没破的话,f[i-1][j-1]+2..f[i][j]这一段也能用剩下的实验次数得到.
【NumberOf WA】
1
【Reviw】
用数学的递推,取代感性的认知.
对问题有了更深的理解。
【Code】
#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int N = 64;
ll f[N+10][N+10],n;
int k;
int main(){
//freopen("F:\\rush.txt","r",stdin);
for (int i = 1;i <= 63;i++)
for (int j = 1;j <= 63;j++)
f[i][j] = f[i-1][j-1] + 1 + f[i][j-1];
while (~scanf("%d%lld",&k,&n) && k){
k = min(k,63);
bool sol = false;
for (int i = 1; i <= 63;i++)
if (f[k][i]>=n){
printf("%d\n",i);
sol = true;
break;
}
if (!sol) puts("More than 63 trials needed.");
}
return 0;
}
【Uva 10934】Dropping water balloons的更多相关文章
- UVa 10934 DP Dropping water balloons
首先想一下特殊情况,如果只有一个气球,我们要确定高度只能从下往上一层一层地测试,因为如果气球一旦爆了,便无法测出气球的硬度. 如果气球有无数个,那么就可以用二分的方法来确定. 一般地,用d(i, j) ...
- 【巧妙算法系列】【Uva 11464】 - Even Parity 偶数矩阵
偶数矩阵(Even Parity, UVa 11464) 给你一个n×n的01矩阵(每个元素非0即1),你的任务是把尽量少的0变成1,使得每个元素的上.下.左.右的元素(如果存在的话)之和均为偶数.比 ...
- 【贪心+中位数】【UVa 11300】 分金币
(解方程建模+中位数求最短累积位移) 分金币(Spreading the Wealth, UVa 11300) 圆桌旁坐着n个人,每人有一定数量的金币,金币总数能被n整除.每个人可以给他左右相邻的人一 ...
- 【UVa 10881】Piotr's Ants
Piotr's Ants Porsition:Uva 10881 白书P9 中文改编题:[T^T][FJUT]第二届新生赛真S题地震了 "One thing is for certain: ...
- 【UVa 116】Unidirectional TSP
[Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- 【UVa 1347】Tour
[Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- 【UVA 437】The Tower of Babylon(记忆化搜索写法)
[题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- 【uva 1025】A Spy in the Metro
[题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- 【POJ 2976】 Dropping Tests
[题目链接] http://poj.org/problem?id=2976 [算法] 0/1分数规划 [代码] #include <algorithm> #include <bits ...
随机推荐
- 对象逆序列化报错:java.lang.ClassNotFoundException
简单的想从保存的对象中又一次解析出对象.用了逆序列化,但是报错: java.lang.ClassNotFoundException: xxxxxxxxxxxx at java.net.URLClass ...
- 设置Webdriver启动chrome为默认用户的配置信息
Webdriver 启动Chrome浏览器时,默认是打开一个新用户,而非默认用户.即新用户没有我们安装扩展程序.但在实际应用中,我们会须要 默认用户安装的一些扩展程序,比方对于某些js或者css样式. ...
- poj--1904--King's Quest(scc建图)
King's Quest Time Limit: 15000MS Memory Limit: 65536KB 64bit IO Format: %I64d & %I64u Submit ...
- P2264 情书(字符串hash90分)
题目背景 一封好的情书需要撰写人全身心的投入.lin_toto同学看上了可爱的卡速米想对她表白,但却不知道自己写的情书是否能感动她,现在他带着情书请你来帮助他. 题目描述 为了帮助lin_toto,我 ...
- 数据绑定的知识点<%%>,<%#%>,<%=%>
1.<% %>用来绑定后台代码 如: < % for(int i=0;i<100;i++) { Reaponse.Write(i.ToString()); } %> 2. ...
- UI Framework-1: Aura and Shell dependencies
Aura and Shell dependencies The diagram below shows the dependencies of Chrome, Ash (Aura shell), vi ...
- Android chromium 1
For Developers > Design Documents > Java Resources on Android Overview Chrome for Android ...
- Linux中常用命令(文件与目录)
1.pwd 查看当前目录(Print Working Directory) 2.cd 切换工作目录(Change Directory) (1)格式:cd [目录位置] 特殊目录: .当前目录 ..上一 ...
- python IO编程-序列化
原文链接:https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/00143192607 ...
- MySQL日志设置及查看方法
MySQL有以下几种日志: 错误日志: -log-err 查询日志: -log 慢查询日志: -log-slow-queries 更新日志: -log-update 二进制日志: -log-bin 默 ...