判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。
示例 1:
输入: 121
输出: true
示例 2:
输入: -121
输出: false
解释: 从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。
示例 3:
输入: 10
输出: false
解释: 从右向左读, 为 01 。因此它不是一个回文数。
#最简单的思路
class Solution:
def isPalindrome(self, x: int) -> bool:
if 0 <= x < 10:
return True
else:
n = str(x)
if n[0] == '-':
return False
elif int(n[0]) >= 0:
m = n[::-1]
q = len(m)
for i in range(int(q / 2)):
if m[i] == m[q - 1 - i]:
if i == q//2-1:
return True
break
continue
return False
break
84 ms 13.6 MB
#换方法
通过比较数值来确定是否是回文,注意负数肯定不是回文
class Solution:
def isPalindrome(self, x: int) -> bool:
if x < 0:
return False
else:
n = int(str(x)[::-1])
return n == x
48 ms 13.4 MB
#超简洁的
class Solution:
def isPalindrome(self, x: int) -> bool:
return str(x) == str(x)[::-1]
52 ms 13.6 MB