鱼C论坛

 找回密码
 立即注册
查看: 3257|回复: 4

[已解决][猴子选大王]请问这段代码错在哪里?

[复制链接]
发表于 2016-1-13 23:54:39 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
下面是利用Python 3.x 的字典写的,发现当剔除一个猴子,往后数字典还剩下3个值得时候,计数出错了~大婶们请赐教~
1. 求出错原因
2. 求该咋写

  1. #!/usr/bin/env python
  2. # coding=utf-8
  3. #Python: 3.x

  4. #猴子选大王 规则
  5. # 1. n只猴子围坐成一个圈,按顺时针方向从1到n编号
  6. # 2. 从1号猴子开始沿顺时针方向从1开始报数,报到m的猴子出局  
  7. # 3. 再从刚出局猴子的下一个位置重新开始报数,如此重复,直至剩下一个猴子,它就是大王

  8. def king(m,n):
  9.     dd = {}
  10.     p = 1
  11.     while(p<=m):
  12.         dd[p] = p
  13.         p = p+1

  14.     j = 1
  15.     while(len(dd) >1):
  16.         for k,v in dd.copy().items():
  17.             if(j == n):
  18.                 dd.pop(k)
  19.                 j = 1
  20.             else:
  21.                 j = j+1
  22.     return dd

  23. print(king(20,5))
复制代码


下面有俩正确的版本,全当学习~~
利用 Python 3.x  列表
  1. #!/usr/bin/env python
  2. #--*-- coding: utf-8 --*--
  3. #Python Version: 3.x
  4. import copy

  5. def MonkeyKing(Number, Sep):
  6.     Monkeys = ['猴子-' + str(x) for x in range(1,Number+1)]
  7.     while True:
  8.         if len(Monkeys) == 1:
  9.             return Monkeys
  10.             break
  11.         if len(Monkeys) < Sep:
  12.             n = Sep % len(Monkeys)
  13.             del Monkeys[n-1]
  14.             if  n != 0:
  15.                 Monkeys = Monkeys[n-1:] + Monkeys[:n-1]
  16.             continue
  17.         for x,y in enumerate(copy.copy(Monkeys), start=1):
  18.             if x % Sep == 0:
  19.                 Monkeys.remove(y)
  20.                 Monkeys = Monkeys[x-1:] + Monkeys[:x-1]
  21.                 break

  22. print(MonkeyKing(20, 5))
复制代码


利用 Python 2.x  字典
  1. #!/usr/bin/python

  2. def king(m,n):
  3.     dd = {}
  4.     p = 1
  5.     while(p<=m):
  6.         dd[p] = p
  7.         p = p+1

  8.     j = 1
  9.     while(len(dd) >1):
  10.         for k,v in dd.items():
  11.             if(j == n):
  12.                 del dd[k]
  13.                 j = 1
  14.             else:
  15.                 j = j+1
  16.     return dd

  17. print king(20,5)
复制代码
最佳答案
2016-1-17 00:04:00
还没仔细分析你的程序。暂时写个简单的。
  1. def MonkeyKing(Number, Sep):
  2.     n = list(range(Number))#生成一个列表
  3.     s = 0#起点位置
  4.     while len(n) > 1:
  5.         s = (s + Sep -1) % len(n)
  6.         n.pop(s)
  7.     return(n[0])
  8. print(MonkeyKing(25, 7)+1)#因为是从0开始做列表的,为了符合题意,加1变为1开始
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2016-1-16 15:52:31 | 显示全部楼层
不要沉
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-1-16 16:45:33 | 显示全部楼层
帮顶
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2016-1-17 00:04:00 | 显示全部楼层    本楼为最佳答案   
还没仔细分析你的程序。暂时写个简单的。
  1. def MonkeyKing(Number, Sep):
  2.     n = list(range(Number))#生成一个列表
  3.     s = 0#起点位置
  4.     while len(n) > 1:
  5.         s = (s + Sep -1) % len(n)
  6.         n.pop(s)
  7.     return(n[0])
  8. print(MonkeyKing(25, 7)+1)#因为是从0开始做列表的,为了符合题意,加1变为1开始
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2016-1-17 16:47:25 | 显示全部楼层
冬雪雪冬 发表于 2016-1-17 00:04
还没仔细分析你的程序。暂时写个简单的。

学习了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2026-2-19 06:05

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表