热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

python实现二十四点

给定n个数字,计算出一个满足24点的表达式:比如1,11,2,1:(111)*21基本思路就是枚举计算顺序(在一开始进行一次全排列),括号,加减乘除。其实有很多是重复计算过了的。

给定n个数字,计算出一个满足24点的表达式:比如1,11,2,1:(11+1)*2/1


基本思路就是枚举计算顺序(在一开始进行一次全排列),括号,加减乘除。其实有很多是重复计算过了的。这个程序我为了高效找到一个解就算了,但是我们把程序稍微修改就可以找到所有的解(表达顺序可能会重复,比如1+2和2+1),同时也可以计算多个数字的组合。

def compute(x,y,op):if op=='+':return x+yelif op=='*':return x*yelif op=='-':return x-yelse:return x/y if y else Nonedef exp(p,iter=0):from itertools import permutationsif len(p)==1:return [(p[0],str(p[0]))]operation = ['+','-','*','/']ret = []p = permutations(p) if iter==0 else [p]for array_n in p:#print(array_n)for num in range(1,len(array_n)):ret1 = exp(array_n[:num],iter+1)ret2 = exp(array_n[num:],iter+1)for op in operation:for va1,expression in ret1:if va1==None:continuefor va2,expression2 in ret2:if va2==None:continuecombined_exp = '{}{}' if expression.isalnum() else '({}){}'combined_exp += '{}' if expression2.isalnum() else '({})'new_val = compute(va1,va2,op)ret.append((new_val,combined_exp.format(expression,op,expression2)))if iter==0 and new_val==24:return ''.join(e+'\n' for x,e in ret if x==24)return ret
print(exp([2,3,4,11,1,3]))

这里写图片描述


:

EXP = {}
def exp(array_n,target,iter=0):if len(array_n)==1:return [(array_n[0],str(array_n[0]))]operation = ['+','-','*','/']ret = []for num in range(1,len(array_n)):exp1 = array_n[:num]exp2 = array_n[num:]ret1 = EXP[exp1] if exp1 in EXP else exp(exp1,target,iter+1)ret2 = EXP[exp2] if exp2 in EXP else exp(exp2,target,iter+1)EXP[exp1] = ret1EXP[exp2] = ret2for op in operation:for va1,expression in ret1:if va1==None:continuefor va2,expression2 in ret2:if va2==None:continuecombined_exp = '{}{}' if expression.isalnum() else '({}){}'combined_exp += '{}' if expression2.isalnum() else '({})'new_val = compute(va1,va2,op)ret.append((new_val,combined_exp.format(expression,op,expression2)))if iter==0 and new_val==target:#print('ans')return ''.join(e for x,e in ret if x==target)return ret if iter else None
def search(array):record = set()from itertools import permutationsfor p in permutations(array):if p in record:continuerecord.add(p)ret = exp(tuple(p),100)if ret:print(ret);break

推荐阅读
  • 本文详细解析了Python中的os和sys模块,介绍了它们的功能、常用方法及其在实际编程中的应用。 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 毕业设计:基于机器学习与深度学习的垃圾邮件(短信)分类算法实现
    本文详细介绍了如何使用机器学习和深度学习技术对垃圾邮件和短信进行分类。内容涵盖从数据集介绍、预处理、特征提取到模型训练与评估的完整流程,并提供了具体的代码示例和实验结果。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
  • 本文介绍如何使用 Python 提取和替换 .docx 文件中的图片。.docx 文件本质上是压缩文件,通过解压可以访问其中的图片资源。此外,我们还将探讨使用第三方库 docx 的方法来简化这一过程。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • 尽管使用TensorFlow和PyTorch等成熟框架可以显著降低实现递归神经网络(RNN)的门槛,但对于初学者来说,理解其底层原理至关重要。本文将引导您使用NumPy从头构建一个用于自然语言处理(NLP)的RNN模型。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 本文介绍如何使用Python进行文本处理,包括分词和生成词云图。通过整合多个文本文件、去除停用词并生成词云图,展示文本数据的可视化分析方法。 ... [详细]
  • 本文介绍如何使用 Python 的 xlrd 库读取 Excel 文件,并将其数据处理后存储到数据库中。通过实际案例,详细讲解了文件路径、合并单元格处理等常见问题。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • andr ... [详细]
author-avatar
九橙seven
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有