黑马程序员技术交流社区
标题:
动态规划解决扔鸡蛋问题——可以共同讨论一下
[打印本页]
作者:
永远的EOF
时间:
2015-8-17 00:09
标题:
动态规划解决扔鸡蛋问题——可以共同讨论一下
Jzj要来做一个经典的实验:测试鸡蛋壳的坚硬程度。
Jzj正好处于N层高的摩天大楼中,所以通过从某一楼层向下扔鸡蛋来测试鸡蛋壳的坚硬程度。
Jzj有M个鸡蛋,所有的鸡蛋硬度都一样。如果鸡蛋从第L层摔下去没有碎,而在L + 1层摔碎了,那么称鸡蛋的硬度是L。嗯,反正jzj不喜欢吃鸡蛋,所以不用担心浪费的问题。大楼共有N层高,如果在N层还没有摔碎,就认为硬度是N;如果在第1层就碎了,硬度为0。
虽然jzj不喜欢吃鸡蛋,但是jzj的好朋友yk特别喜欢吃鸡蛋。为了帮好朋友保护可怜的小鸡蛋,jzj想知道用这么多鸡蛋,最少摔几次就可以保证测试出它们的硬度。
【输入格式】
一行两个正整数,用空格隔开,没有多余字符。分别是M和N。
【输出格式】
输出最少次数。
【样例】
eggs.in
1 10
eggs.out
10
样例解释
由于只有一个鸡蛋,所以只好一层层试。鸡蛋一旦摔碎,就不能再使用了。
【数据规模】
30%的数据N<=100;
100%的数据N<= 1,000。还有:
1:一个魔术,可以把一个东西变少或者变多。但是变多或变少的模式只有三种。
(1) 变少一个
(2) 变多一个
(3) 变为原来的p次幂(p为任意正整数)。
求至少需要施展几次魔法能够把1根薯条变为n根。
输入一行一个正整数N,表示还能吃N根薯条。
输出一行一个整数,表示最少施展的魔法次数。
数据满足 1≤N≤1000000
2:有N块长度相同的长条木板,把每块木板分成了N个小单元,在这N*N个小单元上选了一些涂成了黑色。不过这样涂完了以后,发现把这N块小木板摆在一起太丑了,请交换其中的一些木板,把这些木板排的漂亮一点。
怎么排才漂亮呢?让所有的黑色小单元都尽量聚集在一起,也就是在以(1,1)(2,2)……(N,N)这条对角线以下的三角形区域里(可以包含对角线)。
要用最少的次数将原来的N个木板排成满足要求的样子,每一次操作可以交换任意两个相邻的木板。
输入第一行一个正整数N,表示木板数量。
下面N行,每行N个数0或1。0表示白色,1表示黑色。
输出一行一个整数,表示最少的操作次数是原图像变为漂亮图像。
数据满足 1≤N≤1000
作者:
T-l-H、小生
时间:
2015-8-17 00:50
本帖最后由 T-l-H、小生 于 2015-8-17 00:52 编辑
你发这种算法的题目,没几个人跟你讨论的啦。这是Java基础的版块,进了就业班的人基本就没什么人逛论坛了,我是个例外,以前当过版主,逛论坛习惯了。而就业班毕业之后的人更加极少跑回来。。。回溯,动态规划,分治法,对树这些算法,很多人看不懂。老师能看懂,但不会回你的贴,哈哈。你搞简单的算法,比如折半查找或者递归或许还有人跟你讨论讨论。。。看你发的一堆主题,基本没回复。
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2