百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

少儿Python每日一题(15):回文数

off999 2024-12-11 16:25 19 浏览 0 评论

原题解答

本次的题目如下所示:

【编程实现】
回文数是指一个像14641这样“对称”的数,即:将这个数的各位数字按相反的顺序重新排列后,所得到的数和原来的数一样。请编程求不同位数数字的回文数的个数。用户输入一个正整数M(2<M<7),M作为回文数的位数。要求输出M位的回文数共有几个。
输入描述:输入一个正整数M
输出描述:输出回文数的个数
【样例输入】
3
【样例输出】
90

要解决这道题目,我们首先得搞清楚回文数的概念。回文数的意思就是各个数位上的数字反序后与原来的数一致,即数字呈现“左右对称”的形式。

这道题很明显还是需要通过枚举的方式来查找符合条件的数。这道题带来的另一个难点是如何通过位数得到所有的范围。以三位数为例:它的范围是100到999,即range(100, 1000)。我们如何通过3这个数字得到100和1000呢?从十进制数的定义上我们可以知道,100是,而1000是。由此可以得出, 枚举的范围是range(10 ** (m-1), 10 ** m)。

下面我们来看一下如何判断一个数是否“左右对称”。

方法一:字符串反向切片

如果我们把数字当作字符串处理,如果它的逆序的切片与它本身完全相同,我们就可以得出它是左右对称的,这个数字就是回文数。我们可以得到程序的代码如下:

m = int(input())
n = 0
for i in range(10 ** (m - 1), 10 ** m):
    s = str(i)
    if s == s[::-1]:
        n += 1
print(n)

方法二:数位前后比较

方法一是利用了Python中强大的字符串切片能力,如果离开了字符串切片的功能,我们还得会利用数学的方法解决这个问题。(尤其是将来想要从Python转C++的同学一定要学会第二种方法)

我们首先要得到各个数位上的数字,如何得到各个数位上的数字前面讲过的,通过除10求余的方法可以得到各个数位上的数字。我们将各个数位上的数字存到一个列表中,将列表的左右两边相对称的数进行逐一比较,如果都相等就可以断定它是回文数。

def is_reverse(n):
    digital = []
    while n:
        digital.append(n % 10)
        n //= 10
    flag = True
    for i in range(len(digital) // 2):
        if digital[i] != digital[len(digital) - i - 1]:
            flag = False
            break
    return flag

m = int(input())
n = 0
for i in range(10 ** (m-1), 10 ** m):
    if is_reverse(i):
        n += 1
print(n)

本题拓展

本题考查的是整数数位的处理和枚举算法,题目难度★★★★

此类题目在比赛真题中还会将其他的知识与回文数进行综合,我们看下面这道题目:

题目描述
求 11 到 n之间(包括 n),既是素数又是回文数的整数有多少个。
输入格式
一个大于 11小于 1000010000 的整数 nn。
输出格式
11到n之间的素数回文数个数。
输入样例
23
输出样例
1
说明/提示
回文数指左右对称的数,如:1111,1212112121。

这道题除了需要判断是否为回文数,还需要是否为素数。素数判断我们可以看我的上一篇文章:哥德巴赫猜想。遇到这种综合的题型,我们可以把每种判断的方法写成一个返回值为布尔值的函数,直接调用函数使用“与”运算符对判断条件进行关联,这样条理会非常清晰。我们看这道题的代码如何书写:

from math import sqrt
def is_prime(n):
    flag = True
    for i in range(2, int(sqrt(n)) + 1):
        if n % i == 0:
            flag = False
            break
    return flag


def is_reverse(n):
    s = str(n)
    return s == s[::-1]


n = int(input())
s = 0
for i in range(11, n + 1):
    if is_prime(i) and is_reverse(i):
        s += 1
print(s) 

相关推荐

win10系统自动重启频繁(win10系统经常自动重启)
  • win10系统自动重启频繁(win10系统经常自动重启)
  • win10系统自动重启频繁(win10系统经常自动重启)
  • win10系统自动重启频繁(win10系统经常自动重启)
  • win10系统自动重启频繁(win10系统经常自动重启)
2010office激活密钥25个字符
2010office激活密钥25个字符

步骤/方式1officeprofessionalplus2010:(office专业版)6QFdx-pYH2G-ppYFd-C7RJM-BBKQ8Bdd3G-xM7FB-Bd2HM-YK63V-VQFdKVYBBJ-TRJpB-QFQ...

2025-11-07 01:03 off999

刷机(刷机软件)

答:用下步骤可把电脑刷机:1、制作启动U盘,如大白菜U盘启动盘,然后将下载的系统iso文件直接复制到U盘的GHO目录下。2、在需要刷机的台式电脑上插入U盘,重启后不停按F12、F11、Esc等快捷键打...

u盘装linux系统教程(u盘安装linux操作系统安装教程图解)

以制作Ubuntulinux系统为例:1、首先要下载Ubuntu系统,在搜索Ubuntu,打开Ubuntu官网。2、然后在下载那里,选择桌面版。3、选择好版本之后,点击下载。4、随后跳转到一个网页,...

系统软件卸载器下载(系统软件卸载器专业版)

小米手机清理安装包有两个方法:1.用安全中心清理,步骤如下:打开安全中心,点击垃圾清理点击右上角的手机瘦身屏幕滑到底部,有一个安装包清理2.用文件管理清理,步骤如下:打开文件管理,选择安装包...

电脑开机不了怎么弄(电脑开机不了怎么弄回来)

1、打开电脑,点击【开始】键,可以直接在桌面左下角点击,也可以点击键盘上的电源键;2、在跳出的菜单栏中点击【控制面板】;3、在【控制面板】页面中,找到【系统和安全】,并点击;4、找到操作中心页面,并点...

root权限获取下载(root权限获取教程)

你好!一般的安卓系统的手机都是可以root的,不过root的方法是不一样的。1,一般的手机可以直接在手机上用手机上的root的软件就可以的,一些root工具都可以的等等。2,在就是小米类型的手机直接刷...

下载百度软件(下载百度软件商店安装不了)
  • 下载百度软件(下载百度软件商店安装不了)
  • 下载百度软件(下载百度软件商店安装不了)
  • 下载百度软件(下载百度软件商店安装不了)
  • 下载百度软件(下载百度软件商店安装不了)
dell笔记本电脑如何重装系统
  • dell笔记本电脑如何重装系统
  • dell笔记本电脑如何重装系统
  • dell笔记本电脑如何重装系统
  • dell笔记本电脑如何重装系统
google浏览器安卓版(google浏览器安卓版华军软件园)
  • google浏览器安卓版(google浏览器安卓版华军软件园)
  • google浏览器安卓版(google浏览器安卓版华军软件园)
  • google浏览器安卓版(google浏览器安卓版华军软件园)
  • google浏览器安卓版(google浏览器安卓版华军软件园)
改ip地址的软件有哪些(改ip的软件真的有用吗)

没有绝对好用的IP修改器,ip修改器只有合适自己的才是最好的。因为IP修改器的使用环境不一样,每个ip修改器功能和特点不同,自己用途和范围选择合适的。比如,有些ip修改器适合修改ip地址,有的IP修改...

台式机安装系统步骤(绝尘侠台式机如何u盘安装系统)

中柏EZbookA13使用U盘重装系统:1、将u盘制作成【u启动u盘启动盘】,接着前往相关网站下载win系统存到u盘启动盘,重启电脑等待出现开机画面按下启动快捷键,选择u盘启动进入到主菜单,选取“【...

台式电脑w7怎么升级w10(台式机win7升级win10)

Win7不够8G内存怎么升级到win10。朋友也就是说你现在在使用win7系统。内存不够8G那就是4G的呀。Windows10最低配置的内存就是4G。所以说你要把windows7升级为window...

电脑怎么下载百度(笔记本电脑怎么下载百度)

电脑下载浏览器步骤如下1.打开电脑浏览器,搜索想要下载的电脑版的浏览器,打开官网2.进入官网,点击立即下载3.出现新建下载任务图标,点击下载,下载安装包4.下载完毕,点击打开5.进入安装界面,点击安装...

gho怎么安装系统(gho怎么重装系统)
  • gho怎么安装系统(gho怎么重装系统)
  • gho怎么安装系统(gho怎么重装系统)
  • gho怎么安装系统(gho怎么重装系统)
  • gho怎么安装系统(gho怎么重装系统)

取消回复欢迎 发表评论: