赞
踩
我想到的最佳的办法就是,把这个数拆分开来,然后进行对称比较。
先看一看我第一遍的菜菜代码:
list1 = [0, 0, 0, 0] # 定义一个长度为4的列表并初始化为0 for i in range(1000,10001): list1[0]=i//1000 list1[1]=i//100%10 list1[2]=i//10%10 list1[3]=i%10 if list1[0]==list1[3] and list1[1]==list1[2]: print(i)Tips:
@1:
‘ // '在python中是整除符号,例:
i=5//2,i=2
i=1200//100,i=12
@2:
'%'不用我说,大家都知道应该是取余符号吧///<---_--->///
然后呢,我找到啦更加简便的一种方法!!!!~~~~~~
def is_palindrome(n): return str(n) == str(n)[::-1] for i in range(1000, 10001): if is_palindrome(i): print(i)这段代码中,我们首先定义了一个函数
is_palindrome
,它接受一个整数参数n,将其转换为字符串,然后比较这个字符串是否与其反转后的字符串相等。如果相等,说明这个整数是一个回文数。然后,我们在1000到10000之间进行循环,对于每个数,我们调用
is_palindrome
函数判断是否为回文数,如果是,则打印该整数。
今天,又学会了一种方法呢~~~~~~
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。