方法一:逐位判断
原理:用一个while循环,将一个数每次都取出首位和末位,判断是否相等,只要有一次不相等退出即可。
回文数的判断条件:加入一个变量位数,如果这个数是奇数,位数为1时,即最中间那一位数,此时退出即可,同理,偶数,位数为0时,退出。
问题:
如何判断位数
如何逐位取值
优点:思路简单
解决:
判断位数下面程序即可
y=x
weishu=0
while x:
weishu+=1
x=x//10
先将判断的x赋值给y,当x不为0时,表明现在x还有位数,位数+1,x/10减少一位,但要记住,用地板除(//)直接得到int整数,否则用/会出现浮点数
逐位取值:
a=y//(10**(weishu-1))
b=y%10
if a!=b:
print("不是回文数。")
break
weishu-=2
y=y//10
y=y%(10**weishu)
取得首位只要地板除以相应的位数,把首位后面的数舍去,比如一个五位数,地板除10000(10的4次方,所以是位数-1),就会得到首位