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

news2025/1/8 4:58:56

[导读]:超平老师的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.coloradmin.cn/o/1591477.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

深入解析API技术:原理、实现与应用

在现代软件开发中,API(应用程序接口)扮演着至关重要的角色。API 允许不同的软件应用程序和系统之间进行通信和数据交换,从而构建出更加高效、灵活和可扩展的软件解决方案。本文将深入解析API技术的原理、实现方法,并附…

FANUC机器人通过ROBOGUIDE实现与实际的机器人进行程序导入导出的具体方法示例

FANUC机器人通过ROBOGUIDE实现与实际的机器人进行程序导入导出的具体方法示例 如下图所示,在电脑的开始菜单中找到”Robot Neiborhood”,点击进入, 如下图所示,设置要连接的机器人名称和主机IP地址(要确保自己的电脑和机器人IP地址在同一网段内),点击Add添加, 添加在线…

TCP 三次握手与四次挥手面试题(计算机网络)

TCP 基本认识 TCP 头格式有哪些? 序列号:在建立连接时由计算机生成的随机数作为其初始值,通过 SYN 包传给接收端主机,每发送一次数据,就「累加」一次该「数据字节数」的大小。用来解决网络包乱序问题。 确认应答号&a…

成都百洲文化传媒有限公司电商领域的新锐力量

在电商服务领域,成都百洲文化传媒有限公司凭借其专业的服务理念和创新的策略,正逐渐成为行业内的翘楚。这家公司不仅拥有资深的电商团队,还以其精准的市场定位和高效的服务模式,赢得了众多客户的信赖和好评。 一、专业团队&#…

基于 FPGA 的 DE1-SoC 功率估算器

Introduction 功耗是当今许多技术都要考虑的重要因素。例如,手机生产商总是谈论他们在电源管理方面的改进,以及如何延长电池的使用寿命。功能与功耗之间的平衡是许多人都在研究的有趣课题。然而,当我们做实验时,我们很少会考虑我…

centos7上docker搭建vulhub靶场

1 vulhub靶场概述 VulHub是一个在线靶场平台,提供了丰富的漏洞环境供安全爱好者学习和实践。 该平台主要面向网络安全初学者和进阶者,通过模拟真实的漏洞环境,帮助用户深入了解漏洞的成因、利用方式以及防范措施。 此外,VulHub还…

信号完整性的常见术语概念(面试常用)

目录 术语 概念一览 1.信号完整性(Signal Integrity) 2.传输线(Transmission Line) 3.特性阻抗(Characteristic Impedance) 4.反射(Reflecti…

Stable Video Diffusion(SV3D)安装和测试(windows10)

SVD 安装教程 1.安装miniconda https://docs.anaconda.com/free/miniconda/index.html 2.创建python环境 conda create --name sv3d python3.10conda activate sv3d3.安装triton2.0.0 下载地址:https://huggingface.co/r4ziel/xformers_pre_built/resolve/mai…

AndroidAutomotive模块介绍(一)整体介绍

前言 Android Automotive 是一个基本 Android 平台,可运行 IVI 系统中预安装的 Android 应用以及可选的第二方和第三方 Android 应用。 本系列文档将会系统的介绍 Android Automotive 的功能、架构、逻辑等。模块逻辑将从 应用api接口、系统服务、底层服务&#x…

Arduino _按键点亮——led

int8_t led_pin13;int8_t led2_pin12; void setup() {// put your setup code here, to run once:pinMode(led_pin, INPUT);//输入pinMode(led2_pin, OUTPUT);//输出 }void loop() {// put your main code here, to run repeatedly:if(digitalRead(led_pin)1){//digitalRead(…

校园通用型发生网络安全事件解决方案

已知校园多教学楼、多教学机房、非标网络机房缺乏防护设备、检测设备、安全保护软件(杀软) 切断所有外网,断网处理!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 部署路由系统可选择爱快、routeros、openwrt。等。可将日志上传到日志分析系统。《这项非必要的》 部署开源防火…

弱口令入侵FE企业管理平台【附口令】

漏洞描述 飞企互联-FE企业运营管理平台 druid路径弱口令,攻击者可能通过尝试弱口令,非法进入系统,恶意操作或者收集信息进一步攻击利用。 漏洞复现 1、Fofa app"飞企互联-FE企业运营管理平台"2、零零信安 (html_banner360浏览…

使用Docker Registry-v2搭建镜像仓库详细教程

我们使用docker来部署私有化镜像仓库… 1、下载 registry:v2 镜像 docker pull registry:22、在私有仓库所在的主机目录新建一个文件夹,用于持久化保存仓库中的镜像 mkdir -p /opt/registry3、启动registry镜像 使用docker镜像启动私有仓库容器服务,…

突破编程_前端_SVG(circle 圆形)

1 circle 元素的基本属性和用法 SVG 的 <circle> 元素用于在SVG文档中绘制圆形。它具有几个基本属性&#xff0c;允许定义圆形的大小、位置、填充颜色和边框样式。以下是 <circle> 元素的基本属性及其详细解释&#xff1a; 1.1 cx 和 cy 描述&#xff1a;这两个…

嵌入式|蓝桥杯STM32G431(HAL库开发)——CT117E学习笔记13:RTC实时时钟

系列文章目录 嵌入式|蓝桥杯STM32G431&#xff08;HAL库开发&#xff09;——CT117E学习笔记01&#xff1a;赛事介绍与硬件平台 嵌入式|蓝桥杯STM32G431&#xff08;HAL库开发&#xff09;——CT117E学习笔记02&#xff1a;开发环境安装 嵌入式|蓝桥杯STM32G431&#xff08;…

用Python编写GUI程序将JPEG文件按文件名顺序插入PDF文件

在Python编程中&#xff0c;处理文件和图像是常见的任务之一。最近&#xff0c;我遇到了一个有趣的问题&#xff1a;如何通过编写一个GUI程序来将一个文件夹中的JPEG文件按文件名顺序插入到一个新的PDF文件中&#xff1f;在这篇博客中&#xff0c;我将分享我使用Python、wxPyth…

基于springboot+vue+Mysql的论坛管理系统

开发语言&#xff1a;Java框架&#xff1a;springbootJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#xff1a;…

【vue】v-model.lazy等(非实时渲染)

v-model&#xff1a;实时渲染v-model.lazy&#xff1a;失去焦点/按回车后&#xff0c;才渲染v-model.number&#xff1a;值转换为数字v-model.trim&#xff1a;去除首尾空格 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8&qu…

1.汉诺塔问题

C力扣 汉诺塔 class Solution { public:void hanota(vector<int>& a, vector<int>& b, vector<int>& c) {dfs(a,b,c,a.size());}void dfs(vector<int>& a, vector<int>& b, vector<int>& c,int n){if(n1){c.push…