汇芳书院

专注计算机视觉、机器学习、分布式计算等领域, 兼聊投资、写作、生活

0%

9. 回文数

给你一个整数 x ,如果 x 是一个回文整数,返回 true ;否则,返回 false 。

回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。

例如,121 是回文,而 123 不是。  

示例 1:

输入:x = 121
输出:true
示例 2:

输入:x = -121
输出:false
解释:从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。
示例 3:

输入:x = 10
输出:false
解释:从右向左读, 为 01 。因此它不是一个回文数。

翻转一半的数

1
2
3
4
5
6
7
8
9
10
11
12
13
class Solution {
public:
bool isPalindrome(int x) {
if (x < 0) return false;
if (x % 10 == 0 && x != 0) return false;
int reverse_num = 0;
while (reverse_num < x) {
reverse_num = reverse_num * 10 + x % 10;
x = x / 10;
}
return reverse_num == x || reverse_num / 10 == x;
}
};

转换为string后双指针遍历

1
2
3
4
5
6
7
8
9
10
11
class Solution {
public:
bool isPalindrome(int x) {
if (x < 0) return false;
std::string s = to_string(x);
for (int i = 0, j = s.size() - 1; i < j; i++, j--){
if (s[i] != s[j]) return false;
}
return true;
}
};
坚持原创分享,您的支持将鼓励我继续创作

欢迎关注我的其它发布渠道

------------- 本文结束,感谢阅读 如有问题可留言交流 -------------