代码拉取完成,页面将自动刷新
// Time: O(logx) = O(1)
// Space: O(1)
class Solution {
public:
bool isPalindrome(int x) {
if (x < 0) {
return false;
}
int temp = x;
int reversed = 0;
while (temp != 0) {
if (isOverflow(reversed, temp % 10)) {
return false;
}
reversed = reversed * 10 + temp % 10;
temp = temp / 10;
}
return reversed == x;
}
private:
bool isOverflow(int q, int r) {
static const int max_q = numeric_limits<int>::max() / 10;
static const int max_r = numeric_limits<int>::max() % 10;
return (q > max_q) || (q == max_q && r > max_r);
}
};
// Time: O(logx) = O(1)
// Space: O(1)
class Solution2 {
public:
bool isPalindrome(int x) {
if(x < 0) {
return false;
}
int divisor = 1;
while (x / divisor >= 10) {
divisor *= 10;
}
for (; x > 0; x = (x % divisor) / 10, divisor /= 100) {
int left = x / divisor;
int right = x % 10;
if (left != right) {
return false;
}
}
return true;
}
};
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。