博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PAT 2-10. 海盗分赃(25)
阅读量:7253 次
发布时间:2019-06-29

本文共 981 字,大约阅读时间需要 3 分钟。

题目链接:

解题思路:参考:

假设一种普通的情况,10颗钻石7个人分。

如果只剩2个人,那么无论2说什么1都会反对,除非他把钻石全给他。也就是下面这种情况。  

(0,10)                                    

如果只剩3个人,3知道了如果自己死了2的处境会很惨,如果想让自己的提议实现只要争取1个人的同意就好了。所以3会给2号一颗钻石2就会同意3的提议。这样就变成了:                                                       

(9,1,0)

如果只剩4个人,4知道了如果自己死了3的方案,如果想让自己的提议实现只要争取2个人的同意就好了。所以4会给2号多一颗钻石,给1号一颗钻石,1和2就会同意4的提议。这样就变成了:

(7,0,2,1)

如果只剩5个人,5知道了如果自己死了4的方案,如果想让自己的提议实现只要争取2个人的同意就好了。所以5会给3号一颗钻石,给1号2颗钻石。这样就变成了:                                                      

(7,0,1,0,2)

如果只剩6个人,6知道了如果自己死了5的方案,如果想让自己的提议实现只要争取3个人的同意就好了。所以6会给4,2号一颗钻石,给3号2颗钻石。这样就变成了:                                                      

(6,0,1,2,1,0)

现在我们可以推出7个人的情况了,7知道了如果自己死了6的方案,如果想让自己的提议实现只要争取3个人的同意就好了。所以7会给4,2号一颗钻石,给3号2颗钻石。这样就变成了:

(6,0,1,2,0,0,1)

 

整个的过程如下:

                                 (0,10)

                           (9, 1, 0)   

                    (7,  0, 2,1)  

              (7 ,0, 1, 0,2) 

         (6,0,1,  2, 1,0)

(6,   0, 1,2,  0, 0,1)

以上的推理当然都是基于一定的假设前提的,最重要的前提就是海盗足够聪明,会考虑极端情况,只讲理性,所以他们会从后面开始考虑。

其实只要仔细观察上述数列我们就会总结出规律:ans=D-P/2-1;除了情况3之外。,情况3的规律是:ans=D-P/2

 

代码如下:

#include
using namespace std;int main(){ int d,p,ans; cin>>d>>p; if(p==3) { ans=d-p/2; } else { ans=d-p/2-1; } cout<
<

  

 

转载于:https://www.cnblogs.com/CHLL55/p/4331367.html

你可能感兴趣的文章
[Sdoi2016]平凡的骰子
查看>>
20159208《网络攻防实践》第二周学习总结
查看>>
C#中创建、打开、读取、写入、保存Excel的一般性代码
查看>>
mysql定义游标
查看>>
两个有序数组合并算法
查看>>
面向对象设计原则之五:迪米特法则
查看>>
GitHub for Windows简单使用
查看>>
c#操作XML
查看>>
微软职位内部推荐-SW Engineer for Skype
查看>>
作为一个测试leader平时应该注意哪些方面
查看>>
【DOM编程艺术】Ajax(Hijax)
查看>>
微信公众平台开发(十) 消息回复总结——用其xml模板
查看>>
iOS.CM5.CM4.CM2
查看>>
菜鸟学T-SQL---------SQL2005读书笔记1
查看>>
Python--函数(全局变量和局部变量)
查看>>
PLSQL Developer 不能连接 oracle 11g 64位 的解决办法
查看>>
byobu相关操作
查看>>
父页面操作嵌套iframe子页面的HTML标签元素
查看>>
在TSQL中用case,when之类同时查多种情况
查看>>
Math,random()返回区间内的随机数
查看>>