两数之和-第12届蓝桥杯选拔赛Python真题精选

[导读]:超平老师的Scratch蓝桥杯真题解读系列在推出之后,受到了广大老师和家长的好评,非常感谢各位的认可和厚爱。作为回馈,超平老师计划推出《Python蓝桥杯真题解析100讲》,这是解读系列的第51讲。

两数之和,本题是2021年3月27日举办的第12届蓝桥杯青少组Python编程选拔赛真题,题目要求对n个整数,统计任意两个数字和为M的组合数量。

先来看看题目的要求吧。

一.题目说明

编程实现:

给定一组包含n个(n > 3) 正整数数据,和一个正整数M,从这n个正整数中任意拿出两个数相加,相加后的结果正好为M的值,计算出这n个正整数中有多少组这样的数据。

例如:

给定一组正整数为:1, 3, 2, 4,正整数M为 3,其中有1组符合要求,为1和2

给定一组正整数为:2, 7, 11, 6, 13,正整数M为 13,其中有2组符合要求,分别为2 和11,7和6

输入描述:

第一行输入n个正整数,正整数之间英文逗号隔开(正整数不能有重复,且n > 3)

第二行输入一个正整数M

输出描述:

输出n个正整数中两个数相加的结果正好为M的组合有几组

样例输入:

2, 7, 11, 6, 13

13

样例输出:

2

02

二.思路分析

这是一道简单的计算题,考查的知识点主要包括循环、列表和枚举算法。

题目看起来比较简单,就是一个简单的组合问题,每次取两个数字进行组合,判断是否等于M即可。

针对此题,通常有如下3种解决方案:

  • 暴力枚举

  • 使用combinations()组合函数

  • 单循环遍历

第一种方案是暴力枚举,也是最好理解的,但是需要嵌套两层循环,效率不高。

第二种方案则是直接使用combinations()组合函数,代码比较简单,效率也高于暴力枚举。

实际上,还有更简单的方法,这就是第三种方案---单循环遍历,充分利用两数之和的特点即可。

以题目给出的样例数据为例:

nums = [2, 7, 11, 6, 13]M = 13

我们只需要遍历一次列表,针对每一个列表项nums[i],判断M - nums[i]是否在列表中,并统计数量。​​​​​​​

第1次:nums[i] = 2,13 - 2 = 11,在列表中,cnt加1第2次:nums[i] = 7,13 - 7 = 6,在列表中,cnt加1第3次:nums[i] = 11,13 - 11 = 2,在列表中,cnt加1第4次:nums[i] = 6,13 - 6 = 7,在列表中,cnt加1第5次:nums[i] = 13,13 - 13 = 0,不在列表中,cnt不变

只需要一次循环,就可以统计出所有的排列,如下:​​​​​​​

[2,11][7,6][11,2][6,7]

很明显,每一对组合都统计了两遍,需要除以2才是最终的结果。

思路有了,接下来,我们就进入具体的编程实现环节。

三.编程实现

根据上面的思路分析,我们使用3种方案来编写程序:

  • 暴力枚举

  • 组合函数

  • 单循环遍历

1. 暴力枚举

所谓暴力枚举,就是使用两层嵌套循环,代码如下:

图片

代码比较简单,说明一点,在获取正整数列表的时候,利用了map()和list()函数。

map()会根据提供的函数对指定序列做映射,使用如下:

map(function, iterable, ...)

调用map()函数,就是序列iterable中的每一个元素都调用一次function 函数,并将返回结果作为新的序列返回。

需要注意的是,在Python2中,map()函数返回的是列表,而Python 3中返回迭代器,所以需要使用list()函数进行转换。

2. 组合函数

直接使用combinations()函数,代码如下:

图片

代码简单,说明3点:

1). 要先导入combinations()函数;

2). 为了方便,我们将满足条件的组合保存到res列表中,最后只需要输出res列表的长度即可;

3). 这里使用了列表推导式的编程技巧,可以直接使用if条件筛选数据,combinations()函数返回的是元组,此处使用list()函数将其转成列表,也可以直接作为元组返回,效果一样。

3. 单循环遍历

根据前面的思路分析,编写代码如下:

图片

核心代码比较简单,注意除法运算需要使用整除,这样得到的才是整数。

至此,整个程序就全部完成了,你也可以输入不同的数字来测试效果啦

四.总结与思考

本题代码在10行左右,涉及到的知识点包括:

  • 循环语句,主要是for...in;

  • 条件语句;

  • 输入处理;

  • 列表的使用;

本题难度中等,要实现题目的要求不难,难的是如何找到最优的方法,提升代码的效率。

在上面给出的3种方案中,前面两种方案的时间复杂度都是O(n2)。相对来说,第二种方案效率要高一些,因为combinations()函数使用了一种优化的算法来生成组合,而不是简单地通过暴力枚举来尝试所有可能的组合。这种优化使得combinations()函数在处理大数据集时仍然能够保持较高的效率。

第三种方案的时间复杂度则为O(n),效率最高。当数据量较大的时候,这种优势会越来越明显。

所以,我们平常在编程的时候,不仅要能解决问题,还要进一步思考如何更好地解决问题,这样才能持续进步,更上一层楼。

超平老师给你留一道思考题,如果给出的数据有重复的,需要怎么处理呢?

顺便来一道经典的算法入门题,看看你能否解决:


给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值的那两个整数并返回它们的数组下标。

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍,你可以按任意顺序返回答案。

输入:nums = [2,7,11,15], target = 9

输出:[0,1]

解释:因为 nums[0] + nums[1] == 9 ,返回 [0, 1] 。


你还有什么好的想法和创意吗,也非常欢迎和超平老师分享探讨。

如果你觉得文章对你有帮助,别忘了点赞和转发,予人玫瑰,手有余香😄

需要源码的,可以移步至“超平的编程课”gzh。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/615621.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SqlServer功能性配置选择

功能性配置 下面的是必选的

记录一下如何腾讯云服务器用客户端连MySQL

我一般喜欢用IDEA连数据库,别问我为啥(就喜欢用一个软件解决所有问题) 当然写SQL语句个人还是觉得sqlyog体验最佳!

【InternLM 实战营第二期-笔记4】XTuner 微调个人小助手认知

书生浦语是上海人工智能实验室和商汤科技联合研发的一款大模型,很高兴能参与本次第二期训练营,我也将会通过笔记博客的方式记录学习的过程与遇到的问题,并为代码添加注释,希望可以帮助到你们。 记得点赞哟(๑ゝω╹๑) XTuner 微调个人小助手…

【笔记】探索生成范式:大型语言模型在信息提取中的作用

探索生成范式:大型语言模型在信息提取中的作用 摘要介绍 🌈你好呀!我是 是Yu欸 🌌 2024每日百字篆刻时光,感谢你的陪伴与支持 ~ 🚀 欢迎一起踏上探险之旅,挖掘无限可能,共同成长&am…

文献分享:《基于中国人群的BRCA胚系突变筛查专家共识(2024年版)》

[摘要] BRCA基因(包括BRCA1和BRCA2)的胚系突变是家族性乳腺癌、卵巢癌等肿瘤的核心风险因素。在人群中,特别是已有肿瘤家族史的高危人群中,BRCA基因检测可以发挥预防性管理作用,有助于降低此类遗…

bugku-web-安慰奖

提示备份 开始扫后台 得到备份文件index.php.bak 得到php代码 <?phpheader("Content-Type: text/html;charsetutf-8"); error_reporting(0); echo "<!-- YmFja3Vwcw -->"; class ctf {protected $username hack;protected $cmd NULL;public f…

【攻防世界】supersqli(堆叠注入)

进入题目环境&#xff0c;有输入框与注入参数&#xff0c;推测类型为SQL注入&#xff1a; 测试--注入类型为数字型还是字符型&#xff0c;构造payload&#xff1a;?inject1 or 12 并提交&#xff1a; 发现页面依然正常&#xff0c;说明注入类型为字符型&#xff0c;则继续检查…

Java基于微信小程序的校园订餐系统

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

SQL语言

一、DDL数据库定义语言 1、登录mySQL mysql -u"用户名" -p"密码" -h"登录地址 -h&#xff1a;默认为本机 示例&#xff1a; 2、查看当前存在的数据库 show databases; 示例&#xff1a; 3、创建数据库database create…

打开Visual Studio后出现Visual Assist报错弹窗

安装了新的VA插件后发现无论如何清理打开VS都会报这个旧版VA报错弹窗&#xff0c;修复VS、重装VA都解决不了 后来进到VS安装目录&#xff0c;删掉一个可疑文件后弹窗再也不出现了

关于Git的一些基础用法

关于Git的一些基础用法 1. 前言2. 使用GitHub/gitee创建项目2.1 创建账号2.2 创建项目2.3 下载仓库到本地2.4 提交代码到远端仓库2.5 查看日志2.6 同步远端仓库和本地仓库 1. 前言 首先说一个冷知识&#xff08;好像也不是很冷&#xff09;&#xff0c;Linux和git的创始人是同…

uniapp小程序中使用video视频播放卡顿

问题:在使用uniapp小程序的video视频播放,视频已经在播放了,但是进度条没走,还是卡顿的状态(测试ios能正常使用,安卓手机会出现此问题) 在网上找了很多方法,最多的说是用:custom-cache"false",试了并没有效果,看来和我问题不一样,后来用了个简单粗暴的方法,发现是有效…