鱼C论坛

 找回密码
 立即注册
查看: 3827|回复: 7

[技术交流] python小练习(019):24点

[复制链接]
发表于 2016-11-22 14:00:14 | 显示全部楼层 |阅读模式

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

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

x
python小练习(018),传送门

相信大家都玩过24点,玩法就不啰嗦了。
按照经典的规则:只允许 +  - * / 和()运算

例如:
>>>
4 5 2 5
Solution:
((5+5)*2)+4 = 24

评分

参与人数 1鱼币 +5 收起 理由
SixPy + 5 热爱鱼C^_^

查看全部评分

本帖被以下淘专辑推荐:

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2016-11-22 14:10:21 | 显示全部楼层
预留2楼
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-11-22 18:52:18 | 显示全部楼层
  1. import itertools as itrs

  2. ops = itrs.product(r'+-*/',repeat=3)
  3. fmt = ['{n1}{op1}{n2}{op2}{n3}{op3}{n4}',
  4.         '{n1}{op1}(({n2}{op2}{n3}){op3}{n4})',
  5.         '(({n1}{op1}{n2}){op2}{n3}){op3}{n4}',
  6.         '({n1}{op1}{n2}){op2}({n3}{op3}{n4})',
  7.         '({n1}{op1}({n2}{op2}{n3}){op3}{n4}',
  8.         '{n1}{op1}({n2}{op2}({n3}{op3}{n4}))',]

  9. s = input('输入4个数字,以空格分隔,例:5 5 2 4\n>')

  10. nums = itrs.permutations(map(str,map(float, s.split())))

  11. for prd in itrs.product(fmt, nums, ops):
  12.     f,n,op = prd
  13.     dic = {'n1':n[0],'n2':n[1],'n3':n[2],'n4':n[3]}
  14.     dic.update({'op1':op[0],'op2':op[1],'op3':op[2]})
  15.     f = f.format(**dic)
  16.     try:
  17.         if eval(f) == 24. :
  18.             print(f.replace('.0',''),'= 24')
  19.     except :
  20.         continue
复制代码
  1. 输入4个数字,以空格分隔,例:5 5 2 4
  2. >3 3 7 7
  3. 7*((3/7)+3) = 24
  4. 7*((3/7)+3) = 24
  5. 7*((3/7)+3) = 24
  6. 7*((3/7)+3) = 24
  7. ((3/7)+3)*7 = 24
  8. ((3/7)+3)*7 = 24
  9. ((3/7)+3)*7 = 24
  10. ((3/7)+3)*7 = 24
  11. 7*(3+(3/7)) = 24
  12. 7*(3+(3/7)) = 24
  13. 7*(3+(3/7)) = 24
  14. 7*(3+(3/7)) = 24
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-11-23 10:09:37 | 显示全部楼层
本帖最后由 SixPy 于 2016-11-23 10:10 编辑


改进~
  1. import itertools as itrs

  2. EPS = 1e-6 # 极小值
  3. ops = itrs.product(r'+-*/',repeat=3)
  4. fmt = ['{n1}{op1}{n2}{op2}{n3}{op3}{n4}',
  5.         '{n1}{op1}(({n2}{op2}{n3}){op3}{n4})',
  6.         '(({n1}{op1}{n2}){op2}{n3}){op3}{n4}',
  7.         '({n1}{op1}{n2}){op2}({n3}{op3}{n4})',
  8.         '({n1}{op1}({n2}{op2}{n3}){op3}{n4}',
  9.         '{n1}{op1}({n2}{op2}({n3}{op3}{n4}))',]

  10. s = input('输入4个数字,以空格分隔,例:5 5 2 4\n>')
  11. nums = itrs.permutations(map(str,map(float, s.split())))

  12. formula = set()
  13. for f,n,op in itrs.product(fmt, nums, ops):
  14.     f = f.format(**{'n1':n[0],'n2':n[1],'n3':n[2],'n4':n[3],
  15.                     'op1':op[0],'op2':op[1],'op3':op[2]})
  16.     try:
  17.         if (f not in formula) and (abs(eval(f)-24.) < EPS) :
  18.             print(f.replace('.0',''),'= 24')
  19.             formula.add(f)
  20.     except :
  21.         continue


  22. input('-结束-')
复制代码
  1. 输入4个数字,以空格分隔,例:5 5 2 4
  2. >3 3 8 8
  3. 8/(3-(8/3)) = 24
  4. -结束-
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2016-11-23 14:04:32 | 显示全部楼层
版主改进得已经很不错了,我就不贴了,大家可以参考版主的解题
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-1-25 08:57:43 | 显示全部楼层
版主的代码,以我的极其有限的知识量,到了formate这里就看不懂了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-1-25 09:01:01 | 显示全部楼层
贴上我的比较粗糙的代码,上半部分是打散13个数的排列,再依次挑出4个数,后面是不停变换4个数排序,再依次添加上运算符号,最后转化为运算式,感觉写的很粗糙,我再研究下版主代码
  1. import numpy as np
  2. import itertools as intr

  3. t = [1,2,3,4,5,6,7,8,9,10,11,12,13]
  4. n = 20
  5. while n:
  6.     np.random.shuffle(t)
  7.     kapai = intr.permutations(t,4)
  8.     for i in kapai:
  9.         input('开始发牌')
  10.         temp = list(i)
  11.         break
  12.     s = ['*','/','+','-']
  13.     list_count = []

  14.     print(temp)
  15.     #temp = [4,5,2,5]
  16.     xunhuan = 24
  17.     input('是否求解')
  18.     print(' ')
  19.     while xunhuan:
  20.         np.random.shuffle(temp)
  21.         for j in intr.combinations_with_replacement(s,3):
  22.             m = '('+str(temp[0])+j[0]+str(temp[1])+')'+j[1]+'('+str(temp[2])+j[2]+str(temp[3])+')'
  23.             count = eval(m)
  24.             if count == 24:
  25.                 print('找到了——————————————————————————')
  26.                 print(m)
  27.                 break
  28.             m = '('+'('+str(temp[0])+j[0]+str(temp[1])+')'+j[1]+str(temp[2])+')'+j[2]+str(temp[3])
  29.             count = eval(m)
  30.             if count == 24:
  31.                 print('找到了——————————————————————————')
  32.                 print(m)
  33.                 break
  34.             m = str(temp[0])+j[0]+'('+str(temp[1])+j[1]+str(temp[2])+')'+j[2]+str(temp[3])
  35.             count = eval(m)
  36.             if count == 24:
  37.                 print('找到了——————————————————————————')
  38.                 print(m)
  39.                 break
  40.             try:
  41.                 m = str(temp[0])+j[0]+'('+'('+str(temp[1])+j[1]+str(temp[2])+')'+j[2]+str(temp[3])+')'
  42.                 count = eval(m)
  43.                 if count == 24:
  44.                     print('找到了——————————————————————————')
  45.                     print(m)
  46.                     break
  47.             except:
  48.                 continue
  49.             
  50.         if count == 24:
  51.             break
  52.         xunhuan -= 1
  53.     else:
  54.         print('不能组成24点')
  55.     print(' ')
  56.               
  57.                
  58.             
  59.         

  60.    
  61.    




  62.     print('╭~~~╮')
  63.     print('(o~.~o)')
  64.     n -= 1

复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-11-24 07:58:21 | 显示全部楼层

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-5-16 06:12

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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