(第八届蓝桥杯国赛)对局匹配(动态规划) 题目链接:“蓝桥杯”练习系统
样例输入: 样例输出: 分析:这道题目我们可以分情况进行讨论,先看一下k=0的情况,也就是不能选取相同分数的人,那么很容易想到有多少种不同的积分,那么答案就是几,下面我重点分析一下k!=0的情况,我们可以对所有的分数进行分组,分组规则就是用分数对k取余所得的余数相同的为一组,这样我们可以分为k组,我们可以发现一个性质就是不同组之间的积分是不可能相差k的,也就是说积分相差为k的人一定在同一组,且组与组之间是相互独立的,那么我们可以分别求出每一组内最多能选取的数目,然后相加即为答案。那怎样求出来每一组内最多能选取的数目呢?我们发现在求每一组内最多能选取的数目时我们可以类比没有上司的舞会那道题目,用f[i][0]表示没有选取分数为i的人时所能选取的最大人数,f[i][1]表示选取分数为i的人时所能选取的最大人数,当我们要选取分数为i的人,肯定是选取所有的分数为i的人,这是利用贪心性质得到的,也是很容易想明白的。下面我们来看一下如何动态转移,先对每一组内的分数进行从小到大排序,比如k=3时,一组内的分数为1,4,7,10,……3*(count-1)+1共count个数,当然每个分数对应的人数可以为0,考虑4这个分数的人,假如我们选取了4这个分数的人,那么一定就不能选取1这个分数的人(我们是从前往后递推的,所以这个时候不需要考虑7),如果我们不选4这个分数的人,那么我们可以选择1这个分数对应的人,也可以不选,只需要从两者取一个最大值即可。按照这个思路,更新完组内所有的数就可以得到该组能够选取的最多的人数为max(f[count][1],f[count][0]),然后类似地求出其他组,把每一组得到的最大值相加即为答案。 下面是代码:
2024最新激活全家桶教程,稳定运行到2099年,请移步至置顶文章:https://sigusoft.com/99576.html
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。 文章由激活谷谷主-小谷整理,转载请注明出处:https://sigusoft.com/26664.html