一、引言
今天上数据结构课,给同学们分享了123456789插入加减运算符等于100的递归解法。突然想起来问问chatGPT是怎么解答的,于是就有了今天的分享。环境:64位Win 10中文版 + 64位Python 3.6.5
《Python程序设计(基于计算思维和新文科建设)》,ISBN:9787121435577,胡凤国,电子工业出版社,2022年6月。本书是电子工业出版社在国内较早采用纸质版+电子版的创新图书发行模式的第一次尝试。本书是这套创新图书的纸质版部分,与之内容互补的电子版图书将稍后出版。基础篇介绍Python程序设计的入门知识,共12章,包括:⑵ Python软件的安装和Python程序运行;⑶ Python的基本概念(对象、数据类型、表达式、内置函数);排错篇总结初学者常遇到的错误并介绍程序调试方法,包含2章:与本书内容互补的电子版图书包含文本篇和应用篇两部分:文本篇:介绍字符集、编码和文本文件读写的知识,包含了对国家规范《通用规范汉字表》8105个汉字当中难以输入和难以显示的汉字的处理。应用篇:介绍Word、Excel、PPT、PDF、图片等常用办公文件的处理,是大家提高办公和科研效率的好帮手。本书配套有详细的PPT和教学大纲,还有全部例题的程序代码和绝大部分思考题的程序代码。本书配套PPT里面还加入了配套电子版图书中的部分内容,比如字符集和编码,不同编码的文本文件的读写,Word、Excel、PPT、PDF等一些常用办公文件的读写。1、大学文科生, 可选本书当Python教材或自学Python的参考书。2、大学理工科学生, 可选本书当自学Python的参考书。可拿本书当工具书,本书的配套程序会为您节省效率,在当前大数据和新文科的背景下,本书可以为相关领域的量化研究提供技术支持。本书配套的电子版图书中的编码和文本处理知识也可以作为理工科教师和科研人员处理文本数据的参考资料之一,毕竟专门开辟章节介绍国家标准《通用规范汉字表》汉字处理的程序设计图书并不多见。
本书有专门的海龟画图章节,有大量的有趣数学题目,可以培养学生的计算思维,适合对编程感兴趣的中小学生阅读,也适合打算让娃参加编程辅导班的家长朋友参考。本书在各大实体书店和网店均有销售。京东、天猫、当当的购买渠道如下(可扫码直达购买页面)。
三、问题
有一个数字序列123456789,请你在这些数字中插入加减号,使得插入加减号得到的表达式的值是100。注意123456789这几个数字的顺序要保持不变,请你把所有符合条件的插入加减号方法都找出来。
四、CharGPT的回答

ChatGPT给出了10个解,其中还有一个解是不对的。其实这个题目有11个解,这么看来,ChatGPT答对了全部11个解中的9个。全部11个正确的解都是哪些呢?
五、正确的11个解及递归解法
胡凤国老师的书《Python程序设计(基于计算思维和新文科建设)》里面就有这11个正确的解,还有求解的程序。
生成这11个解,可以用递归法。递归法的解题思路和程序在本书的第179和180页。
五、非递归解法
我请朋友请ChatGPT帮忙写一个求解本问题的Python程序,ChatGPT居然给出了一个8重循环。
它给出程序运行结果给出了全部11个正确的答案,但是用8重循环(ChatGPT的注释居然说是3层嵌套循环)来进行暴力枚举未免太不Pythonic了,我们人类会怎么进行枚举呢?早在2018年2月份,笔者刚开始学习Python的时候,在董付国老师的微信公众号上看到了这个问题的解法,见:后来,笔者和董付国老师一起给出了一个三进制的解法,见:
这个算法使用了自己编写的函数来进行三进制转换,其实没有必要这么做。笔者后来通过学习发现Python有一个扩展库可以绕过三进制算法直接枚举所有的运算符组合。
比起ChatGPT的8重循环,笔者这个改进的三进制算法是不是简单多了?
六、感谢
感谢董老师分享了这个有趣的问题,感谢W同学和H同学帮我向ChatGPT提问并反馈提问结果。
七、讨论
1、前面说ChatGPT给出了10个解,其中还有一个解是不对的,到底哪一个不对呢,我们能不能用程序把这个不对的表达式找出来?
2、如果有读者朋友发现代码可以改进或者有更简便的做法,欢迎交流。
由于本号文章以辅助教学为主,笔者不建议自己的学生直接拿代码运行,而是建议在理解了思路之后自己敲代码来加深印象,所以本号一般不直接贴代码。如果其他读者朋友有需要代码,请关注本号,直接加笔者微信联系,尽量别给公众号留言(查看不及时,经常漏看一些留言,时间长了无法回复)。欢迎关注微信公众号“语和言”,本公众号将不定期发布对图书《Python程序设计(基于计算思维和新文科建设)》中的Python知识点进行解读和补充的内容。语和言公众号还有读者交流群,读者朋友可以入群一起讨论问题。
欢迎跟图书《Python程序设计(基于计算思维和新文科建设)》的作者胡凤国老师进行交流,电邮:cuchufengguo@163.com。
九、图书目录
图书《Python程序设计(基于计算思维和新文科建设)》目录如下(手机端可以用手指上下滑动下面灰色区域的文字来查看全部目录,电脑端可以用鼠标滚动滚轮或拖动下面文本框右边的滚动条来浏览全部目录):
8.2.4 关于元素可比较的有序序列类对象的通用操作10.3.3 用上下文管理语句with来管理文本文件读写12.12.1 datetime标准库定义的常用类参考文献