题目:
给你一个整数
x
,如果x
是一个回文整数,返回true
;否则,返回false
。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。
- 例如,
121
是回文,而123
不是。示例 1:
输入:x = 121 输出:true示例 2:
输入:x = -121 输出:false 解释:从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。示例 3:
输入:x = 10 输出:false 解释:从右向左读, 为 01 。因此它不是一个回文数。
小白思路:
1、把int类型的参数x转换成string类型。
2、反转字符串。
3、反转后的和原来的对比,一致则是回文数,不一致不是。
class Solution(object):
def isPalindrome(self, x):
"""
:type x: int
:rtype: bool
"""
if x < 0:
return False
return str(x)[::-1] == str(x)
优化思路:
不转化成字符串类型,使用数字来计算,主要思路就是将数字反转。
class Solution(object):
def isPalindrome(self, x):
"""
:type x: int
:rtype: bool
"""
if x < 0:
return False
elif x < 10:
return True
rev, save = 0, x
while x:
rev = rev*10 + x%10
x //= 10
return rev == save