9. Palindrome Number
Problem:
Determine whether an integer is a palindrome. An integer is a palindrome when it reads the same backward as forward.
Example 1:
Input: 121
Output: true
Example 2:
Input: -121
Output: false
Explanation: From left to right, it reads -121. From right to left, it becomes 121-. Therefore it is not a palindrome.
Example 3:
Input: 10
Output: false
Explanation: Reads 01 from right to left. Therefore it is not a palindrome.
Follow up:
Coud you solve it without converting the integer to a string?
思路:
将整数由低位到高位依次压入数组中,然后比较前一半和后一半的值即可。
Solution (C++):
bool isPalindrome(int x) {
if (x < 0) return false;
if (x < 10) return true;
vector<int> vec{};
while (x/10) {
vec.push_back(x%10);
x /= 10;
if (x < 10) { vec.push_back(x); break; }
}
bool is_pal = true;
for (int i = 0; i <= (vec.size()-1) / 2; ++i) {
if (vec[i] != vec[vec.size()-1-i]) {
is_pal = false;
break;
}
}
return is_pal;
}
性能:
Runtime: 44 ms Memory Usage: 9.5 MB
思路:
Solution (C++):
性能:
Runtime: ms Memory Usage: MB
相关链接如下:
知乎:littledy
GitHub主页:https://github.com/littledy
github.io:https://littledy.github.io/
欢迎关注个人微信公众号:小邓杂谈,扫描下方二维码即可
作者:littledy
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利。

浙公网安备 33010602011771号