小白的疑问:回文数好高级,有什么规律能让机器也识别(这问题等我回了之后感觉好简单,但是刚看到的时候觉得好难--。)
a.首先理解回文数
题目其实都已经告诉你了,回文数就是从左边读和右边读都是一样的。
把概念多读几遍,也许小白就能懂了。
【左右读是一样的】【左右读是一样的】【左右读是一样的】...
那就是正序和倒序是完全相等的。
b.怎么让程序正着读和反着读从而识别回文数?
运用字符串的切片、正序、倒序操作。
直接举例子能更好理解,下面是我自己的练习。切片方式用[ , , ,]表示就行,其中三个参数分别代表 【开始位置,结束位置,步长】
如果我们输入iloveyou这个字符串
str=iloveyou
第三个参数默认为步长为1.
当需要倒序的时候,第三个参数为-1
所以要判断一个数是不是回文数,需要把他变为字符串格式然后进行切片,步长为-1即可。
c. 题目要求所有回文数之和为指定的输入。
在判断回文数的时候已经是在字符串上进行的,所以要算该字符串的个位数之和用for循环依次算各位的和即可。
注意:题目要求输出五位和六位的数,要用一个大的判断条件才行。
for i in range(100000,1000000)
用循环算字符串各位之和。
num=0 for i in range(n): num+=str[i]
d.最终完整程序
n=int(input()) for i in range(10000,1000000): str1=str(i) num=0 if str1==str1[::-1]: for j in range(len(str1)): num+=int(str1[j]) if num==n: print(i)