鸡国福利
题目:
鸡国为了表彰鸡国每一只鸡在过去一年的优秀表现,打算在接下来的 n 天中每天给鸡国的一只鸡发 1 袋或者 2 袋“鸡币”(鸡国的通用货币)作为福利。国王要求每天来领钱鸡互不相同,即来领过钱的鸡不能再来,否则将受到严厉的处罚。
但聪明的鸡国老百姓侦察后发现国王每天发的钱袋子里面装的钱数量是不一样的(同一天的相同),第 i 天发的每一袋钱为 ai元。如果第 i 天来领钱的鸡领 1 袋钱,它可以获得ai元的“鸡币”,如果它领 2 袋钱,则可以获得 2×ai元“鸡币”,当然它也可以放弃,则第i 天的钱国王收回国库。
由于鸡国生活条件优越和鸡的贪念等原因,当第 i 天领钱的鸡同时满足以下两个条件时
它才会感到幸福:
(1)领到的钱不能低于鸡国的平均收入 m 元。
(2)要跟它前面领了钱且感到幸福的鸡一样幸福或者更幸福。
仁慈的国王希望鸡国的每一只鸡都能感到幸福,请你帮国王规划一下在这 n 天中怎样给每一只发钱才能让最多的鸡感到幸福?
但聪明的鸡国老百姓侦察后发现国王每天发的钱袋子里面装的钱数量是不一样的(同一天的相同),第 i 天发的每一袋钱为 ai元。如果第 i 天来领钱的鸡领 1 袋钱,它可以获得ai元的“鸡币”,如果它领 2 袋钱,则可以获得 2×ai元“鸡币”,当然它也可以放弃,则第i 天的钱国王收回国库。
由于鸡国生活条件优越和鸡的贪念等原因,当第 i 天领钱的鸡同时满足以下两个条件时
它才会感到幸福:
(1)领到的钱不能低于鸡国的平均收入 m 元。
(2)要跟它前面领了钱且感到幸福的鸡一样幸福或者更幸福。
仁慈的国王希望鸡国的每一只鸡都能感到幸福,请你帮国王规划一下在这 n 天中怎样给每一只发钱才能让最多的鸡感到幸福?
首先我们简化这个题目,要你做的就是:
现在给你n个数,每个数你可以把它变成自身的两倍,然后让你求最长不下降子序列的长度
首先,时间3000ms是不能接受n^2的算法的(n<=10^6)
不过我知道一种nlogn的算法,来给大家讲一讲:
我们设f[i]为长度为i的不下降序列的末尾的数的最小值,len为当前的最长不下降子序列的长度
我们1ton扫,每次有两种情况:
if a[i]>=f[len] ——> len++,f[len]:=a[i]
else
二分出一个x,使得f[x]<=a[i] and f[x+1]>a[i]
f[x]:=a[i];
这样最后的len就是答案,时间O(nlogn)
现在我们讲这道题怎么用这个算法
对于一个a[i],如果a[i]>=f[len],则直接len++,插到队尾
不然就把它插到f里面
前提是>=m
a[i]*2一样
最后输出len即可