鱼C论坛

 找回密码
 立即注册
查看: 1294|回复: 5

python实现(2,3,4,5)的四则运算(+,-,*,/,**)得到26

[复制链接]
发表于 2019-4-9 19:47:10 | 显示全部楼层 |阅读模式

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

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

x
题目要求是这样的:
使用PYTHON的int运算+,-,*,/,**和数字2,3,4,5,构造一个表达式,使得所有4个数字和3个运算符各一次,计算得到26.

我的思路是使用穷举的方法,但是实际运行的结果是不正确的,请大神看看哪里的逻辑有问题,附上代码;

  1. s=[2,3,4,5]
  2. def convert(op):
  3.     if (op==0):
  4.         return '+'
  5.     elif (op==1):
  6.         return '-'
  7.     elif (op==2):
  8.         return '*'
  9.     elif (op==3):
  10.         return '/'
  11.     elif (op==4):
  12.         return '**'

  13. def cal(a,b,op):
  14.     if (op==0):
  15.         return a+b
  16.     elif (op==1):
  17.         return a-b
  18.     elif (op==2):
  19.         return a*b
  20.     elif (op==3):
  21.         return a/b
  22.     elif (op==4):
  23.         return a**b

  24. def result(n1,op1,n2,op2,n3,op3,n4):
  25.     return str(n1)+convert(op1)+str(n2)+convert(op2)+str(n3)+convert(op3)+str(n4)

  26. def getresult():
  27.     r1=0
  28.     r2=0
  29.     r3=0
  30.     for i in range(0,4):
  31.         for j in range(0,4):
  32.             for k in range(0,5):
  33.                 if(i!=j):
  34.                     r1=cal(s[i],s[j],k)
  35.                     for l in range(0,4):
  36.                         for m in range(0,5):
  37.                             if (i!=l and j!=l and k!=m):
  38.                                 r2=cal(r1,s[l],m)
  39.                                 for n in range(0,4):
  40.                                     for o in range(0,5):
  41.                                         if (i!=n and j!=n and l!=n and k!=o and m!=o ):
  42.                                             r3=cal(r2,s[n],o)
  43.                                             if (r3==26):
  44.                                                 return result(s[i],k,s[j],m,s[l],o,s[n])
  45. print(getresult())
复制代码


运行结果是3/2+5*4,这个结果明显不是26.
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-4-9 20:08:28 | 显示全部楼层
因为程序没有考虑运算的优先级,它是相当于
>>> (3/2+5)*4
26.0
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-4-9 20:28:30 | 显示全部楼层
错误同上
  1. op=['+','-','*','/','**']
  2. num=['2','3','4','5']
  3. def f(n,p):
  4.     return n[0]+p[0]+n[1]+p[1]+n[2]+p[2]+n[3]
  5. from itertools import permutations as pm
  6. for n in pm(num,4):
  7.     for p in pm(op,3):
  8.         if 26==eval(f(n,p)):
  9.             print(f(n,p))
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-4-10 09:35:21 | 显示全部楼层
冬雪雪冬 发表于 2019-4-9 20:08
因为程序没有考虑运算的优先级,它是相当于
>>> (3/2+5)*4
26.0

我修改了一下,可以出来一个结果,经过运算也正确了。
就是将r1,r2转换为int类型,并且,在getresult函数中的第二个if语句中添加and k!=m这个条件。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-4-10 09:37:01 | 显示全部楼层

我试运行了一下您的代码,结果有四个:
4-3+5**2,4+5**2-3,5**2-3+4,5**2+4-3,经过计算,结果确实都是26,所以你说的错误在哪?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-4-10 09:38:40 | 显示全部楼层
安以陌 发表于 2019-4-10 09:37
我试运行了一下您的代码,结果有四个:
4-3+5**2,4+5**2-3,5**2-3+4,5**2+4-3,经过计算,结果确实都是2 ...

错误的分析同版主,你的算法都是两两计算结合的,并没有考虑算式加减乘除幂运算优先级,所以可能出错
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-15 04:19

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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