首先明白单词Palindrome的意思回文,就是考虑对程序的问题。
考虑把int 转换成 str,然后用双指针来判断是否相等,条件是 while(i<j) 战胜8.7%
class Solution {
/**** 回文。
* 负数不是回文
******/
public:
bool isPalindrome(int x) {
if(x<0) return false;
string str;
for(;x!=0;x/=10){
str.push_back(x%10);
}
int i=0;int j=str.size()-1;
while(i<j){
if(str[i]!=str[j]) return false;
i++;
j--;
}
std::cout<<str;
return true;
}
};

本文介绍了一种通过将整数转换为字符串,并使用双指针技术来判断该整数是否为回文的方法。该方法首先检查整数是否为负数,如果是则直接返回不是回文。之后将整数转换为字符串并利用双指针从两端向中间移动对比字符是否相同。
622

被折叠的 条评论
为什么被折叠?



