Python算法100例-1.5 借书方案知多少

2024-02-11 06:44

本文主要是介绍Python算法100例-1.5 借书方案知多少,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  • 1.问题描述
  • 2.问题分析
  • 3.算法设计
  • 4.完整的程序
  • 5.问题拓展

1.问题描述

小明有5本新书,要借给A、B、C三位小朋友,若每人每次只能借1本,则可以有多少种不同的借法?

2.问题分析

本题属于数学中常见的排列组合问题,即求从5个数中取3个不同数的排列组合的总数。我们可以将5本书进行1~5编号,A、B、C三个人每次都可以从5本书中任选1本,即每人都有5种选择,由于1本书不可能同时借给一个以上的人,因此只要这三个人所选书的编号不同,则即为一次有效的借阅方法。

3.算法设计

对于每个人所选书号,我们可以采用穷举循环来实现,即从每个人可选书号(1、2、3、4、5)的范围内进行穷举,从而得到可行的结果。对于第一个人的选择,可以用循环将其列出,即for a in range(1,6)。同理,对于第二个人、第三个人可以用同样的方法。由于一本书只能借给一个人,故第二个人的选择会受到第一个人的限制,最后一个人的选择会受到第二个人的限制,即后面的选择都是在前面选择的前提下进行的,所以可采用循环的嵌套来解决问题。

利用循环解决问题的时候,找到循环的三要素,即循环变量的初值、循环的控制条件和使循环趋于结束的循环变量值的改变是进行编程的关键。读者可参照1.4节的例子来找一下本题中所对应的循环三要素。本题的输出结果有一个条件限制:三个人所选书号各不相同。这在输出语句前只要用一个if语句“if a != b and a != c and c != b”进行判断即可。

4.完整的程序

根据上面的分析,编写程序如下:

%%time
# 借书方案知多少if __name__=="__main__":#A、B、C三位小朋友,5本书,每人每次只能借一本#用a、b、c分别表示三人所选图书的编号i = 0                                                                   # i表示有效借阅次数print("A,B,C三人所选书号分别为:")#用来控制A借阅图书的编号for a in range(1, 6):#用来控制B借阅图书的编号for b in range(1, 6):#用来控制C借阅图书的编号for c in range(1, 6):if a != b and a != c and c != b:print("A:%2d  B:%2d  C:%2d    " %(a, b, c) ,  end='')i += 1if i % 4 == 0:print()                             #换行print("共有%d种有效借阅方法" %i)
A,B,C三人所选书号分别为:
A: 1  B: 2  C: 3    A: 1  B: 2  C: 4    A: 1  B: 2  C: 5    A: 1  B: 3  C: 2    
A: 1  B: 3  C: 4    A: 1  B: 3  C: 5    A: 1  B: 4  C: 2    A: 1  B: 4  C: 3    
A: 1  B: 4  C: 5    A: 1  B: 5  C: 2    A: 1  B: 5  C: 3    A: 1  B: 5  C: 4    
A: 2  B: 1  C: 3    A: 2  B: 1  C: 4    A: 2  B: 1  C: 5    A: 2  B: 3  C: 1    
A: 2  B: 3  C: 4    A: 2  B: 3  C: 5    A: 2  B: 4  C: 1    A: 2  B: 4  C: 3    
A: 2  B: 4  C: 5    A: 2  B: 5  C: 1    A: 2  B: 5  C: 3    A: 2  B: 5  C: 4    
A: 3  B: 1  C: 2    A: 3  B: 1  C: 4    A: 3  B: 1  C: 5    A: 3  B: 2  C: 1    
A: 3  B: 2  C: 4    A: 3  B: 2  C: 5    A: 3  B: 4  C: 1    A: 3  B: 4  C: 2    
A: 3  B: 4  C: 5    A: 3  B: 5  C: 1    A: 3  B: 5  C: 2    A: 3  B: 5  C: 4    
A: 4  B: 1  C: 2    A: 4  B: 1  C: 3    A: 4  B: 1  C: 5    A: 4  B: 2  C: 1    
A: 4  B: 2  C: 3    A: 4  B: 2  C: 5    A: 4  B: 3  C: 1    A: 4  B: 3  C: 2    
A: 4  B: 3  C: 5    A: 4  B: 5  C: 1    A: 4  B: 5  C: 2    A: 4  B: 5  C: 3    
A: 5  B: 1  C: 2    A: 5  B: 1  C: 3    A: 5  B: 1  C: 4    A: 5  B: 2  C: 1    
A: 5  B: 2  C: 3    A: 5  B: 2  C: 4    A: 5  B: 3  C: 1    A: 5  B: 3  C: 2    
A: 5  B: 3  C: 4    A: 5  B: 4  C: 1    A: 5  B: 4  C: 2    A: 5  B: 4  C: 3    
共有60种有效借阅方法
CPU times: user 1.21 ms, sys: 0 ns, total: 1.21 ms
Wall time: 1.21 ms

5.问题拓展

如果前两个人所选书号相同,那么无论第三个人所选书号与前两人相同与否都是无效的借阅方法。因此在执行第三个循环之前可先判定前两人的编号是否相同,进而提高程序效率。实现代码如下:

%%time
# 借书方案知多少
if __name__=="__main__":# A、B、C三位小朋友,5本书,每人每次只能借一本# 用a、b、c分别表示三人所选图书的编号i = 0                                                                   # i表示有效借阅次数print("A,B,C三人所选书号分别为:")a = 1while a <= 5:b = 1while b <= 5:c = 1while c <= 5 and a != b:if a != c and b != c:               # 控制有效借阅组合print("A:%2d  B:%2d  C:%2d    " % (a, b, c), end='')i += 1if i % 4 == 0:print()                             # 换行c += 1b += 1a += 1print("共有%d种有效借阅方法" % i)

对原程序稍做修改之后,在长度上虽没有改进,仍有三层循环,但是在程序的执行效率上有了很大的提高。对于原程序中的第三层循环来说,不管a和b的取值是否相同,循环都要重复进行5次;而修改后的程序在进入循环体之前首先判断a和b的取值,如果两者取值相同,则内层循环无须重复执行5次便可结束。本题的数据较小,在处理数据很大的问题时使用该方法效率的提高会更加明显。

这篇关于Python算法100例-1.5 借书方案知多少的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/699105

相关文章

详解如何通过Python批量转换图片为PDF

《详解如何通过Python批量转换图片为PDF》:本文主要介绍如何基于Python+Tkinter开发的图片批量转PDF工具,可以支持批量添加图片,拖拽等操作,感兴趣的小伙伴可以参考一下... 目录1. 概述2. 功能亮点2.1 主要功能2.2 界面设计3. 使用指南3.1 运行环境3.2 使用步骤4. 核

Python 安装和配置flask, flask_cors的图文教程

《Python安装和配置flask,flask_cors的图文教程》:本文主要介绍Python安装和配置flask,flask_cors的图文教程,本文通过图文并茂的形式给大家介绍的非常详细,... 目录一.python安装:二,配置环境变量,三:检查Python安装和环境变量,四:安装flask和flas

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

基于Python打造一个可视化FTP服务器

《基于Python打造一个可视化FTP服务器》在日常办公和团队协作中,文件共享是一个不可或缺的需求,所以本文将使用Python+Tkinter+pyftpdlib开发一款可视化FTP服务器,有需要的小... 目录1. 概述2. 功能介绍3. 如何使用4. 代码解析5. 运行效果6.相关源码7. 总结与展望1

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable

Python基础文件操作方法超详细讲解(详解版)

《Python基础文件操作方法超详细讲解(详解版)》文件就是操作系统为用户或应用程序提供的一个读写硬盘的虚拟单位,文件的核心操作就是读和写,:本文主要介绍Python基础文件操作方法超详细讲解的相... 目录一、文件操作1. 文件打开与关闭1.1 打开文件1.2 关闭文件2. 访问模式及说明二、文件读写1.