Python算法输出1-9数组形成的结果为100的所有运算式

作者:wkcagd 时间:2022-05-02 22:45:48 

问题:

编写一个在1,2,…,9(顺序不能变)数字之间插入+或-或什么都不插入,使得计算结果总是100的程序,并输出所有的可能性。例如:1 + 2 + 34–5 + 67–8 + 9 = 100。


from functools import reduce
operator = {
1: '+',
2: '-',
0: ''
}
base = ['1', '2', '3', '4', '5', '6', '7', '8', '9']
def isHundred(num):
#转化为8位3进制数,得到运算符数组
arr = []
for index in range(8):
 index = 7 - index
 arr.append(num // (3 ** index))
 num -= (num // (3 ** index)) * (3 ** index)
arr = map(lambda x: operator[x], arr)
#合并得到运算式
formula = reduce(lambda x, y: x + y, zip(base, arr))
formula = list(formula)
formula.append('9')
formula = ''.join(formula)
#计算运算式结果
res = eval(formula)
return res, formula
if __name__ == '__main__':
#所有可能的结果
total = 3 ** 8
for i in range(total):
 res, formula = isHundred(i)
 if res == 100:
  print(formula+' = 100')

结果:


/usr/bin/python3.5 /home/kang/workspace/Qt3d/test.py
123+45-67+8-9 = 100
123+4-5+67-89 = 100
123-45-67+89 = 100
123-4-5-6-7+8-9 = 100
12+3+4+5-6-7+89 = 100
12+3-4+5+67+8+9 = 100
12-3-4+5-6+7+89 = 100
1+23-4+56+7+8+9 = 100
1+23-4+5+6+78-9 = 100
1+2+34-5+67-8+9 = 100
1+2+3-4+5+6+78+9 = 100

下面再看一个小实例:

题目:输入三个整数x,y,z,请把这三个数由小到大输出。

程序分析:我们想办法把最小的数放到x上,先将x与y进行比较,如果x>y则将x与y的值进行交换,然后再用x与z进行比较,如果x>z则将x与z的值进行交换,这样能使x最小。

程序源代码:


#!/usr/bin/python
# -*- coding: UTF-8 -*-

l = []
for i in range(3):
x = int(raw_input('integer:\n'))
l.append(x)
l.sort()
print l

以上实例输出结果为:


integer:
8
integer:
5
integer:
6
[5, 6, 8]

来源:http://www.cnblogs.com/wkcagd/p/7775102.html

标签:python,实例
0
投稿

猜你喜欢

  • Vue中的常用指令及用法总结

    2024-06-07 16:05:31
  • ASP访问数量统计代码

    2011-04-08 10:59:00
  • 对python3 sort sorted 函数的应用详解

    2022-08-01 23:44:45
  • 使用Postman测试需要授权的接口问题

    2022-10-18 15:14:23
  • 纯js实现遮罩层效果原理分析

    2024-02-24 01:32:14
  • 基于RequireJS和JQuery的模块化编程日常问题解析

    2024-04-19 10:17:04
  • mysql学习笔记之数据引擎

    2024-01-25 12:38:28
  • Python实现获取邮箱内容并解析的方法示例

    2021-07-31 01:40:11
  • MySQL UPDATE时主键冲突引发的思考

    2008-06-21 17:00:00
  • Python实现随机漫步功能

    2021-02-05 20:44:45
  • vue3中给数组赋值丢失响应式的解决

    2024-05-22 10:44:41
  • Python基于百度API识别并提取图片中文字

    2023-02-06 13:51:25
  • 浅谈JavaScript的自动垃圾收集机制

    2023-08-13 15:18:57
  • pytorch 中forward 的用法与解释说明

    2021-08-10 04:14:44
  • SQL中的连接查询详解

    2024-01-25 08:06:40
  • 用Python实现群发邮件

    2023-10-30 20:04:36
  • 关于Python中request发送post请求传递json参数的问题

    2022-12-23 06:20:33
  • Python中unittest的数据驱动详解

    2021-06-04 18:26:05
  • 详解基于Transformer实现电影评论星级分类任务

    2022-01-08 20:31:23
  • Go语言操作数据库及其常规操作的示例代码

    2024-01-14 07:05:46
  • asp之家 网络编程 m.aspxhome.com