沉得好快,
没人做出来吗?(再没人做我只好自己解答了)
我喜欢创造,一只扑腾着翅膀向天空飞翔的乌鸦
看不懂的贪心算法。好难,请给出详尽的解释以及你的理解,谢谢!
我对这道题的解答:(最好定义一个分数运算,保证准确度)
初看这个题目,我也有点摸不找头脑,方法是搜索(这是我想了一番后确定的)
我想最理想的情况是我搜索道的第一个解就是最优解(谁不希望这样)
先说搜索算法:以分2个为例:把以个分数分成两个,其中必有以个比原分数的1/2大,那么范围就有了,我只要搜索所有比原分数的1/2大的分数(很有限),然后判断另一个分数是否满足条件就可以了。搜索应该从满足条件最小的分数到最大的——这样可以保证第一次就搜索到最优解。
我已经把分两个的算法说了,由于要晚自习,没时间了,剩下的大家想想,我晚上放学再来看看。
再说分成N个的算法:
这N个数里面必然有一个比原数的1/N大,那我先找出所有满足条件的数。剩下的就变成了一个N-1的问题。
很明显是可以有第归函数解决的(定义一个分N份的函数,第归调用直到N=2)
当然这么搜索可能会重复,而且是否为最优还不得而知,解决得办法是让搜索有序化,这一次搜索到得数必须比上一
个小(这是我上一个题目的精华思想,在这里也起了大作用)这样得到的必定是最小得加数,要让这个数尽量大(最优
解得要求)就是前面得数尽量小,解决这个只要确定搜索方向就可以了——从小到大搜
举个例子:对于2/5大于它得一半的分数有:1/2,1/3,1/4我们把搜索方向确定为1/4到1/2,这样先搜索到得数总是比后搜索到得数小,也就是最后剩下得数会大。
把搜索函数写好后,先搜索N=2得情况,没有,再搜索N=3的情况,以次类推,
当然这样的搜索你可能会怀疑N太大时…… 其实就我目前的测试看来,还没出现过N>3的情况。
好了,有不懂的可以提出来。我又要去上学了。(如果需要我把代码也贴上来)