输出回文数-第11届蓝桥杯选拔赛Python真题精选
[导读]:超平老师的Scratch蓝桥杯真题解读系列在推出之后,受到了广大老师和家长的好评,非常感谢各位的认可和厚爱。作为回馈,超平老师计划推出《Python蓝桥杯真题解析100讲》,这是解读系列的第23讲。
输出回文数,本题是2020年5月31日举办的第11届蓝桥杯青少组Python编程选拔赛真题,题目要求编程输出1到N(包含N)之间所有的回文数及总的个数。
先来看看题目的要求吧。
一.题目说明
提示信息:
一任意自然数n,若将n的各个位数倒序排列,所得到的数与n相等,例如:1234321倒序排列后仍为1234321,则称之为一个回文数。
编程实现:
用户输入一个正整数(N),输出1到N(包含N)之间所有的回文数及一共有多少个(注意:个数前边加"*")。
样例输入:
100
样例输出:
1
2
3
......
99
*18
评分标准:
-
5分:能正确输出一组回文数及个数;
-
10分:能正确输出两组回文数及个数;
-
15分:能正确输出三组及三组以上回文数及个数。
二.思路分析
这是一道经典的数论问题,考查的知识点主要包括循环和字符串运算。
一个自然数,如果从左向右看和从右向左看数字都一样,换句话说,就是“数字排列左右对称”,就把它叫做“回文数”。
比如121、5335、6084806都是回文数,当然,由同一个数字组成的数,如11,999也是回文数。
针对回文数的判断,方法比较多,最常用的有如下两种:
-
字符串反转
-
逐位判断
字符串反转的思路比较简单,就是将数字转成字符串,然后再利用Python的字符串切片运算得到逆序数字串,如果二者相等,就是回文数。
逐位判断的思路是以中间数字为对称点,看左右对称的两个数字是否相等, 如图:
上图给出的数字个数是奇数的情况,中间的数字是孤立的,可以不用判断,如果数字个数为偶数,则刚好成对出现。
为了简化程序,我们可以定义一个函数,用于判断给定数字是否为回文数,返回结果是布尔值。
思路有了,接下来,我们就进入具体的编程实现环节。
三.编程实现
根据上面的思路分析,我们分两步来编写程序:
-
定义函数判断回文数
-
输出回文数及其个数
1. 定义函数判断回文数
我们先使用方案一,即字符串反转的方式,定义函数如下:
代码非常简洁,这里使用了Python编程中的切片技巧,其用法如下:
str[start: stop: step]
其中:
-
start 表示切片的起始位置(默认为0,即字符串的开头)。
-
stop 表示切片的结束位置(默认为字符串的末尾)。
-
step 表示切片的步长,决定了我们每次取多远的字符。当步长为正数时,从左往右取字符;当步长为负数时,从右往左取字符。
在上面的代码中,我们使用 s[: : -1] 来切片,其中 start 和 stop 都没有指定,因此默认为字符串的开头和末尾,而 step 设为 -1,表示从字符串的最后一个字符开始,每次向前取一个字符,直到字符串的开头,这样就得到了反转的字符串。
接下来,我们再使用方案2,即逐位比较的方式来定义函数,代码如下:
代码不多,简单说明3点:
1). 首先要找到字符串的中间位置,对于长度为奇数的字符串来说,中间位不用处理,所以需要使用整除运算;
2). 以mid为对称点,前后对称的两个数字,其下标之和为字符串长度 - 1,建议结合特例法来理解,比如12321数字串,其长度为5,第一位下标为0,最后一位下标为4,其和为4,第二位下标为1,倒数第二位下标为3,二者的和为4;
3). 一旦对称的两个数字不相等,肯定不是回文数,直接返回False,结束函数;如果循环执行完,都没有返回False,说明是回文数,直接返回True。
2. 输出回文数及其个数
接下来就可以对1到N之间的所有数字进行遍历,调用函数判断是否为回文数,如果是则输出该数字,并统计回文数的个数,其代码如下:
这部分代码比较简单,强调3点:
1). 前面定义的两个函数,选择其中一个就可以了;
2). 在调用函数的时候,需要使用str()函数将i转成字符串;
3). 最后输出数量的时候,不要忘了”*“。
运行程序,输入100,结果如下:
至此,整个程序就全部完成了,你也可以输入不同的数字来测试效果。
四.总结与思考
本题的分数为30分,代码在10行左右,涉及到的知识点包括:
-
输入和输出处理;
-
循环语句,主要for...in循环;
-
字符串处理,尤其是切片技巧;
-
函数的灵活使用;
题目难度中等,解决本题的关键是要找到回文数的特点,并找到判断回文数的方法。
在具体实现的时候,可以使用函数的编程思想将判断过程封装成一个函数,这样就可以把一个复杂问题拆分成两个简单的问题,从而简化代码,这样可以避免出现一些不必要的错误。
在对字符串进行反转操作时,用到了切片的编程技巧,这是Python的专用方法,简单而强大,这也是很多人都喜欢Python的原因,一定要熟练掌握哦。
超平老师给你留一道思考题,除了上面讲到的两种方法,还有没有其它方法,具体又是如何实现的呢?
你还有什么好的想法和创意吗,也非常欢迎和超平老师分享探讨。
如果你觉得文章对你有帮助,别忘了点赞和转发,予人玫瑰,手有余香😄
需要源码的,可以移步至“超平的编程课”gzh。
相关文章:
输出回文数-第11届蓝桥杯选拔赛Python真题精选
[导读]:超平老师的Scratch蓝桥杯真题解读系列在推出之后,受到了广大老师和家长的好评,非常感谢各位的认可和厚爱。作为回馈,超平老师计划推出《Python蓝桥杯真题解析100讲》,这是解读系列的第23讲。 输出回文数&#…...
内存溢出会导致模块测试正常,植入系统失败
前些天,遇到了一个问题:需要在系统中添加一个小功能,单独测试,然后植入系统。 代码使用了从网上下载的函数,模块单独运行,没有问题,但是放在系统中运行就会出问题。 不得已的情况下,…...
【taro react】 ---- QRCode 二维码生成
1. 需求分析 需要将输入的值转换为图片资源;由于只是单纯的展示,所以不需要很多比如加 logo 等复杂功能;不需要后端生成,直接前端操作;使用的第三方库尽可能小,功能单一;最后选择使用 qrcode-generator 库,只有 40kb。2. 使用第三方库 qrcode-generator 3. 转换 base…...
rk3566 armbian修复usb2.0并挂载U盘
文章目录 usb接口修复一 执行命令二 修改rk3566-panther-x2.dts⽂件三 查看是否识别 U盘格式化、挂载一 U盘格式化1.1 查看U盘1.2 查看U盘文件系统类型1.3 格式化为ext4系统 二 挂载U盘2.1 手动挂载2.2 自动挂载(可选) usb接口修复 一 执行命令 将位于…...
猫头虎博主第9期赠书活动:《YOLO目标检测》计算机AI视觉实战YOLO人工智能目标检测与跟踪图像处理深度学习图像检测书籍
博主猫头虎的技术世界 🌟 欢迎来到猫头虎的博客 — 探索技术的无限可能! 专栏链接: 🔗 精选专栏: 《面试题大全》 — 面试准备的宝典!《IDEA开发秘籍》 — 提升你的IDEA技能!《100天精通Golang》…...
python 如何将英语单词翻译成中文
要将英语单词翻译成中文,可以使用 Python 的第三方库 googletrans。该库使用 Google Translate 提供的 API 来进行翻译。 首先,需要安装 googletrans 库。可以使用以下命令在终端或命令提示符中安装: pip install googletrans4.0.0-rc1然后…...
Linux_CentOS_7.9_MySQL_5.7配置数据库服务开机自启动之简易记录
前言: 作为运维保障,都无法准确预估硬件宕机的突发阶段,其生产数据实时在产出,那作为dba数据库服务的其重要性、必要性就突显而出。这里拿虚拟机试验做个配置记录,便于大家学习参考。 # 如出现服务器重启后登入报错无…...
js实现拖动盒子查看内容 内容拖动
一.分析实现过程 1.鼠标拖动的操作是,按下鼠标不松,拖动鼠标,就需要监听鼠标点击事件(onmousedown),鼠标拖动事件(onmousemove) 2.鼠标拖动事件的监听时机,是在按下鼠标之后监听的,所以鼠标拖动事件需要放在鼠标按下事…...
[C#]winform利用seetaface6实现C#人脸检测活体检测口罩检测年龄预测性别判断眼睛状态检测
【官方框架地址】 https://github.com/ViewFaceCore/ViewFaceCore 【算法介绍】 SeetaFace6是由中国科技公司自主研发的一款人脸识别技术,它基于深度学习算法,能够快速、准确地识别出人脸,并且支持多种应用场景,如门禁系统、移动…...
c++ execl 执行 重定向
#include <unistd.h>int main() {pid_t childPid fork(); // 创建子进程if (childPid 0) {// 子进程// 关闭标准输入、输出和错误流close(STDIN_FILENO);close(STDOUT_FILENO);close(STDERR_FILENO);// 打开要写入的文件int fd open("output.txt", O_WRONLY…...
uni-app中实现元素拖动
uni-app中实现元素拖动 1、代码示例 <template><movable-area class"music-layout"><movable-view class"img-layout" :x"x" :y"y" direction"all"><img :src"musicDetail.bgUrl" :class&…...
Java系列-Class.forName和ClassLoader.loadClass的区别
Class.forName 和 ClassLoader.loadClass 是 Java 中两种加载类的方式,它们的主要区别在于加载类的时机和对异常的处理。 1.Class.forName Class.forName 是一个静态方法,用于在运行时加载类。它返回一个 Class 对象,但在加载类的过程中&am…...
找不到模块 “path“ 或其相对应的类型声明
src别名的配置 在开发项目的时候文件与文件关系可能很复杂,因此我们需要给src文件夹配置一个别名 // vite.config.ts import {defineConfig} from vite import vue from vitejs/plugin-vue import path from path export default defineConfig({plugins: [vue()],r…...
Linux第17步_安装SSH服务
secure shell protocol简称SSH。 目的:在进行数据传输之前,SSH先对联级数据包通过加密技术进行加密处理,然后再进行数据传输,确保数据传输安全。 1、在安装前,要检查虚拟机可以上网,否则可能会导致安装失…...
C语言—数据类型
变量和基本数据类型 变量类型的概念 变量是在程序中可以发生变化的量,变量是有类型的,变量的类型决定了变量存储空间的大小以及如何解释存储的位模式。 1字节(Byte)8位(bit) 定义格式 存储类型 数据…...
静态网页设计——多彩贵州(HTML+CSS+JavaScript)(dw、sublime Text、webstorm、HBuilder X)
前言 声明:该文章只是做技术分享,若侵权请联系我删除。!! 感谢大佬的视频:https://www.bilibili.com/video/BV1cK411v7R2/?vd_source5f425e0074a7f92921f53ab87712357b 源码:https://space.bilibili.com…...
unity PDFRender Curved UI3.3
【PDF】PDFRender 链接:https://pan.baidu.com/s/1wSlmfiWTAHZKqEESxuMH6Q 提取码:csdn 【曲面ui】 Curved UI3.3 链接:https://pan.baidu.com/s/1uNZySJTW0-pPwi2FTE6fgA 提取码:csdn...
基于深度学习的停车位关键点检测系统(代码+原理)
摘要: DMPR-PS是一种基于深度学习的停车位检测系统,旨在实时监测和识别停车场中的停车位。该系统利用图像处理和分析技术,通过摄像头获取停车场的实时图像,并自动检测停车位的位置和状态。本文详细介绍了DMPR-PS系统的算法原理、…...
C#,入门教程(09)——运算符的基础知识
上一篇: C#,入门教程(08)——基本数据类型及使用的基础知识https://blog.csdn.net/beijinghorn/article/details/123906998 一、算术运算符号 算术运算符号包括:四则运算 加 , 减-, 乘*, 除/与取模%。 // 加法,运算 int va 1 …...
企业出海数据合规:GDPR中的个人数据与非个人数据之区分
GDPR仅适用于个人数据,这意味着非个人数据不在其适用范围内。因此,个人数据的定义是一个至关重要的因素,因为它决定了处理数据的实体是否要遵守该法规对数据控制者规定的各种义务。尽管如此,什么是个人数据仍然是当前数据保护制度…...
如何在Ubuntu搭建Emlog博客站点并发布至公网可随时远程访问管理界面——“cpolar内网穿透”
文章目录 前言1. 网站搭建1.1 Emolog网页下载和安装1.2 网页测试1.3 cpolar的安装和注册 2. 本地网页发布2.1 Cpolar临时数据隧道2.2.Cpolar稳定隧道(云端设置)2.3.Cpolar稳定隧道(本地设置) 3. 公网访问测试总结 前言 博客作为使…...
【金猿CIO展】是石科技CIO侯建业:算力产业赋能,促进数字经济建设
侯建业 本文由是石科技CIO侯建业撰写并投递参与“数据猿年度金猿策划活动——2023大数据产业年度优秀CIO榜单及奖项”评选。 大数据产业创新服务媒体 ——聚焦数据 改变商业 是石科技(江苏)有限公司成立于2021年,由国家超级计算无锡中心与…...
TypeScript 类
目录 1、实例 2、创建类的数据成员 3、创建实例化对象 4、完整实例 5、类的继承 6、继承类的方法重写 7、static关键字 8、instanceof运算符 9、访问控制修饰符 10、类和接口 TypeScript 是面向对象的 JavaScript。类描述了所创建的对象共同的属性和方法。支持面向对…...
Oracle分区表
文章目录 A. varchar2类型时间字段(20240102)分区实战1. 表要不要分区2. 将已经存在的表改造为分区表(时间字段,varchar2类型)3. 增加分区3.1 增加分区3.2 置换分区,不会复制索引,不要用这种语法建表,这是专门为置换分区用的3.3 分…...
【leetcode】力扣算法之旋转图像【难度中等】
题目描述 给定一个 n n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。 你必须在 原地 旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要 使用另一个矩阵来旋转图像。 用例 输入: matrix [[1,2,3],[4,5,6],[7,8,9]] 输出&…...
【Java集合类篇】HashMap的数据结构是怎样的?
HashMap的数据结构是怎样的? ✔️HashMap的数据结构✔️ 数组✔️ 链表 ✔️HashMap的数据结构 在Java中,保存数据有两种比较简单的数据结构: 数组和链表(或红黑树)。 HashMap是 Java 中常用的数据结构,它实现了 Map 接口。Has…...
Spring 应用合并之路(一):摸石头过河 | 京东云技术团队
公司在推进降本增效,在尝试多种手段之后,发现应用太多,每个应用都做跨机房容灾部署,则最少需要 4 台机器(称为容器更合适)。那么,将相近应用做一个合并,减少维护项目,提高…...
Android13配置selinux让system应用可读sys,proc,SN号
system权限应用读sys,proc目录及SN号 Android13预置的system应用,需要读/sys, /proc目录,读(SN)serial number号, 需要修改selinux配置,否则会报avc错. 其修改方法会比Android11复杂一些. 实现 system_app.te中添加…...
防勒索病毒攻击的关键措施
【作者】朱向东 中原银行 高级工程师 在当今数字化时代,勒索病毒成为了企业和个人面临的一项严峻威胁。勒索病毒攻击可以导致数据丢失、系统瘫痪以及经济损失。为了保护自己和组织的利益,采取一系列的防范措施是至关重要的。下面是一些关键的措施&#…...
代表团坐车 - 华为OD统一考试
OD统一考试(B卷) 分值: 100分 题解: Java / Python / C++ 题目描述 某组织举行会议,来了多个代表团同时到达,接待处只有一辆汽车可以同时接待多个代表团,为了提高车辆利用率,请帮接待员计算可以坐满车的接待方案输出方案数量。 约束: 一个团只能上一辆车,并且代表团…...
做网站排名seo/百度移动端点赞排名软件
潜水好久,也不知道写些什么,就放点好玩的东西,目前.net虽然开源了,但对跨平台这块,还得依靠mono,以前在windows下做界面编程,用到的就是winform和wpf,mono虽然支持winform࿰…...
dedecms 生成网站地图/开网店如何运营和推广
传送门:bzoj4036 Min-Max容斥 设max(S)\max(S)max(S)为集合SSS中的最大值,min(S)\min(S)min(S)为集合SSS中的最小值,∣S∣|S|∣S∣为集合SSS的大小,则存在: max(S)∑T⊆S(−1)∣T∣1min(T)min(S)∑T⊆S(−1)∣T∣1max…...
怎么买网站域名/网络营销渠道有哪几种
算法描述 K-means算法是一种被广泛使用的基于划分的聚类算法,目的是将n个对象会分成k个簇。算法的具体描述如下: 随机选取k个对象作为簇中心;Do计算所有对象到这k个簇中心的距离,将距离最近的归入相应的簇;重新计算每个…...
北京市工商注册网上服务系统/seo网络优化前景怎么样
DRBD简介 Distributed Replicated Block Device(DRBD)是一个用软件实现的、无共享的、服务器之间镜像块设备内容的存储复制解决方案。 数据镜像:实时、透明、同步(所有服务器都成功后返回)、异步(本地服务器成功后返回ÿ…...
seo sem 外贸建站 网站建设 文化墙设计/百度指数分析报告
返回元组:实现多返回值 func calculate(v1: Int, v2: Int) -> (sum: Int, difference: Int, average: Int) {...
成都建设厅网站/沈阳关键词seo
嗯,小子自己以前也为安装和卸载SQL2008、2005苦恼过。自己在网上从查找了好多资料,最终解决了自己的问题。下面的我将用两则博文来分享我所找到的有关于如何完全卸 载SQL2008、2005的方法。希望能够对大家有所帮助。 大家在卸载SQL 2008、2005时可以参考…...