题目:
给你一个整数 x ,如果 x 是一个回文整数,返回 true ;否则,返回 false 。
回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。例如,121 是回文,而 123 不是。
示例 1:
输入:x = 121
输出:true
class Solution(object):
def isPalindrome(self, x):
"""
:type x: int
:rtype: bool
"""
a = str(x)
b = len(a)
#负数直接排除
if x < 0:
return False
for i in range(b):
if a[i] != a[b-i-1]:
return False
return True
解题思路:利用循环结构与判断结构套用的方法,通过第一个数与最后一个数,第二个与倒数第二个进行比较,如果一直正确就继续,如果错了就返回False的方法
重点解析:
1.b =len(a):用来提取a的长度,为后续循环做铺垫
2.按照原题要求,所有的负数都是不符合的。没有两边的符号
3.a[i]的第一个数字是a[0]
4.所以我们要找到a[最后一个数],如果使用a[-i]。第一个数字会是a[0]和a[-0]作比较出现问题。所以,最后一个数其实是b-i-1,也就是a[-1]来做比较。
4.return的False和True均为布朗数,需要首字母大写。
处理结果:
这段代码是比较简洁的
来源:力扣(LeetCode)