本文实例讲述了C#实现的海盗分金算法。分享给大家供大家参考,具体如下:

海盗分金的故事
5个海盗抢到了100颗宝石,每一颗都一样的大小和价值连城。
他们决定这么分:
1。抽签决定自己的号码(1,2,3,4,5)
2。首先,由1号提出分配方案,然后大家5人进行表决,当且仅当半数和超过半数的人同意时,按照他的提案进行分配,否则将被扔入大海喂鲨鱼。
3。如果1号死后,再由2号提出分配方案,然后大家4人进行表决,当且仅当半数和超过半数的人同意时,按照他的提案进行分配,否则将被扔入大海喂鲨鱼。
4。依次类推......
问题:第一个海盗提出怎样的分配方案才能够使自己的收益最大化
条件:每个海盗都是很聪明的人,如果前面的人提出的方案对自己没好处肯定会否决,如果好处比后面持续下去的方案好就投票。
解决:网上很多解决方法(百度百科:http://baike.baidu.com/view/5221.htm ),下面就是算法总结,目的就是让自己得到1半或以上的票。
算法:从后向前来推理,
i 海盗分为1-5号,如果只剩下第4,5号海盗两个人分配,4号则给自己投一票>=50%,条件成立,自己独吞总金币,5号什么也得不到。
ii 3号推出了4号的方案,发一枚金币给5号,拉一票,因为5号知道在4号的方案中自己得不到所以投3号一票,加上3号投自己的一票>=50%条件成立,3号获得100-1=99枚金币。
iii 2号得出3号方案,给4号一枚金币拉一票,同理,2号票数(1+1)/4>=50%条件成立,获得100-1=99枚金币。
iv 1号推断2号方案中,3号和5号不能获得金币,于是给他们各一枚金币则拉两票,(1+1+1)/5>=50%条件成立,自己获得100-1-1=98枚金币。
从上面的推论可以看出,从后向前依次推,如果上一次分配中获得金币的海盗本次分配中将不能获得金币。
using System;
class pirateAssignGold
{
public static void Main()
{
int pirates=5; //海盗总数
int gold=100; //金币总数
int joinNum; //加入分配的海盗数
int[] poke=new int[pirates+1]; //每个海盗一个口袋
int ticket; //票数计数器
for(int i=pirates;i>=1;i--){
joinNum=pirates-i+1; //此次加入分配的海盗数
ticket=0;
for(int j=pirates;j>=i;j--)
{
if((pirates-j+1)==joinNum) //如果本海盗就是此次加入分配的最后一个海盗
{
poke[j]=gold; //利益最大化,把还剩的金币全给他
gold=gold-poke[j];
ticket=ticket+1;
}
else
{
if(poke[j]>0) //此海盗已经获得了金币
{
gold=gold+poke[j]; //推论中本次分配者会使上一次获得金币的海盗什么都没有。
poke[j]=0;
}
else
{
poke[j]=1; //推论中上一次分配中没有获得金币的海盗会在本次获得金币。
gold=gold-1;
ticket=ticket+1;
}
}
}
if((double)ticket/(double)joinNum<0.5){ break;} //总得票数/此次加入分配的海盗数>=50%则此次分配成立,否则失败
}
for(int n=1;n<=5;n++){
Console.WriteLine("海盗{0}获得金币数{1} ",n,poke[n]);
}
Console.ReadKey();
}
}
更多关于C#相关内容感兴趣的读者可查看本站专题:《C#数据结构与算法教程》、《C#程序设计之线程使用技巧总结》、《C#常见控件用法教程》、《WinForm控件用法总结》、《C#数组操作技巧总结》及《C#面向对象程序设计入门教程》
希望本文所述对大家C#程序设计有所帮助。
# C#
# 海盗分金
# 算法
# C# 生成高质量缩略图程序—终极算法
# C#的3DES加密解密算法实例代码
# C#常见算法面试题小结
# asp.net(c#)两种随机数的算法
# 可用抽考题
# c#汉诺塔的递归算法与解析
# C#加密算法汇总(推荐)
# 基于C#代码实现九宫格算法横竖都等于4
# c# 实现MD5
# SHA1
# SHA256
# SHA512等常用加密算法源代码
# 基于私钥加密公钥解密的RSA算法C#实现方法
# c#哈希算法的实现方法及思路
# C#数据结构与算法揭秘五 栈和队列
# .net C# 实现任意List的笛卡尔乘积算法代码
# 的人
# 自己的
# 一票
# 一枚
# 程序设计
# 分配方案
# 将被
# 都是
# 相关内容
# 第一个
# 给他
# 会在
# 价值连城
# 一颗
# 感兴趣
# 数据结构
# 给自己
# 给大家
# 只剩下
# 给他们
相关文章:
官网建站费用明细查询_企业建站套餐价格及收费标准指南
如何在服务器上配置二级域名建站?
nginx修改上传文件大小限制的方法
如何快速生成专业多端适配建站电话?
如何制作算命网站,怎么注册算命网站?
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
导航网站建站方案与优化指南:一站式高效搭建技巧解析
常州自助建站费用包含哪些项目?
相册网站制作软件,图片上的网址怎么复制?
建站主机选哪种环境更利于SEO优化?
建站之星如何开启自定义404页面避免用户流失?
盘锦网站制作公司,盘锦大洼有多少5G网站?
清除minerd进程的简单方法
建站主机SSH密钥生成步骤及常见问题解答?
如何快速生成高效建站系统源代码?
网站制作公司排行榜,四大门户网站排名?
湖北网站制作公司有哪些,湖北清能集团官网?
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
如何快速辨别茅台真假?关键步骤解析
企业网站制作公司网页,推荐几家专业的天津网站制作公司?
网站设计制作企业有哪些,抖音官网主页怎么设置?
建站之星各版本价格是多少?
建站之星如何一键生成手机站?
c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】
如何用IIS7快速搭建并优化网站站点?
潍坊网站制作公司有哪些,潍坊哪家招聘网站好?
seo网站制作优化,网站SEO优化步骤有哪些?
重庆市网站制作公司,重庆招聘网站哪个好?
如何在Windows服务器上快速搭建网站?
建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析
高防服务器如何保障网站安全无虞?
深圳网站制作费用多少钱,读秀,深圳文献港这样的网站很多只提供网上试读,但有些人只要提供试读的文章就能全篇下载,这个是怎么弄的?
道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?
国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?
如何设置并定期更换建站之星安全管理员密码?
活动邀请函制作网站有哪些,活动邀请函文案?
清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?
网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?
Python多线程使用规范_线程安全解析【教程】
高端建站三要素:定制模板、企业官网与响应式设计优化
如何通过免费商城建站系统源码自定义网站主题与功能?
广州网站建站公司选择指南:建站流程与SEO优化关键词解析
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
网站网页制作专业公司,怎样制作自己的网页?
宝塔新建站点为何无法访问?如何排查?
,怎么在广州志愿者网站注册?
建站主机是否属于云主机类型?
SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?
如何在建站主机中优化服务器配置?
*请认真填写需求信息,我们会在24小时内与您取得联系。