【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的更多相关文章

  1. UVa 10934 DP Dropping water balloons

    首先想一下特殊情况,如果只有一个气球,我们要确定高度只能从下往上一层一层地测试,因为如果气球一旦爆了,便无法测出气球的硬度. 如果气球有无数个,那么就可以用二分的方法来确定. 一般地,用d(i, j) ...

  2. 【巧妙算法系列】【Uva 11464】 - Even Parity 偶数矩阵

    偶数矩阵(Even Parity, UVa 11464) 给你一个n×n的01矩阵(每个元素非0即1),你的任务是把尽量少的0变成1,使得每个元素的上.下.左.右的元素(如果存在的话)之和均为偶数.比 ...

  3. 【贪心+中位数】【UVa 11300】 分金币

    (解方程建模+中位数求最短累积位移) 分金币(Spreading the Wealth, UVa 11300) 圆桌旁坐着n个人,每人有一定数量的金币,金币总数能被n整除.每个人可以给他左右相邻的人一 ...

  4. 【UVa 10881】Piotr's Ants

    Piotr's Ants Porsition:Uva 10881 白书P9 中文改编题:[T^T][FJUT]第二届新生赛真S题地震了 "One thing is for certain: ...

  5. 【UVa 116】Unidirectional TSP

    [Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  6. 【UVa 1347】Tour

    [Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  7. 【UVA 437】The Tower of Babylon(记忆化搜索写法)

    [题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  8. 【uva 1025】A Spy in the Metro

    [题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  9. 【POJ 2976】 Dropping Tests

    [题目链接] http://poj.org/problem?id=2976 [算法] 0/1分数规划 [代码] #include <algorithm> #include <bits ...

随机推荐

  1. MyEclipse常见错误汇总,中英注释版(长期更新)

    No.1 当一条语句漏写分号时错误描述如下 Syntax error, insert ";" to complete Statement(语法错误:插入分号完成语句描述) No.2 ...

  2. HDOJ 4975 A simple Gaussian elimination problem.

    和HDOJ4888是一样的问题,最大流推断多解 1.把ISAP卡的根本出不来结果,仅仅能把全为0或者全为满流的给特判掉...... 2.在残量网络中找大于2的圈要用一种类似tarjian的方法从汇点開 ...

  3. 语法错误: unexpected ''); ?></span></span></h2> ' (T_CONSTANT_ENCAPSED_STRING), expecting ',' or ';'

    语法错误: unexpected ''); ?></span></span></h2>' (T_CONSTANT_ENCAPSED_STRING), expe ...

  4. 安卓开发--HttpDemo02

    package com.cnn.httpdemo02; import android.app.Activity; import android.os.Bundle; import android.vi ...

  5. BZOJ 1001 平面图与对偶图的转化 最短路Or最大流

    思路: 1.按照题意求最小割 转换成最大流用Dinic解 2. 转换成对偶图 求最短路 Dinic: //By SiriusRen #include <queue> #include &l ...

  6. nginx 配置若干问题

    配置nginx,遇到的几个小问题: 1. 报错信息: # nginx -t nginx: [warn] conflicting server name , ignored 分析解决: 配置文件中,重复 ...

  7. 运行npm start vue.js项目 出现 npm ERR! missing script: start 错误

    npm ERR! missing script: start 错误 有可能缺少依赖包,运行nmp install安装依赖(一般都依赖很多包,过程有点慢),安装完后发现多一个 node_modules文 ...

  8. CF85E Guard Towers(二分答案+二分图)

    题意 已知 N 座塔的坐标,N≤5000 把它们分成两组,使得同组内的两座塔的曼哈顿距离最大值最小 在此前提下求出有多少种分组方案 mod 109+7 题解 二分答案 mid 曼哈顿距离 >mi ...

  9. 钩子(hooks)—webhook-使用钩子自动触发部署

    钩子(hooks)-webhook http://fighter.blog.51cto.com/1318618/1670667 https://www.lovelucy.info/auto-deplo ...

  10. [Python] Read and plot data from csv file

    Install: pip install pandas pip install matplotlib # check out the doc from site import pandas as pd ...