leetcode题解 9. Palindrome Number

Posted on 2018-04-06 18:28  wangziyan  阅读(96)  评论(0)    收藏  举报

9. Palindrome Number

题目:

Determine whether an integer is a palindrome. Do this without extra space.

click to show spoilers.

Some hints:

Could negative integers be palindromes? (ie, -1)

If you are thinking of converting the integer to string, note the restriction of using extra space.

You could also try reversing an integer. However, if you have solved the problem "Reverse Integer", you know that the reversed integer might overflow. How would you handle such case?

There is a more generic way of solving this problem.

其实就是判断一个数字是不是回文数字。

一开始的思路是找到开始的数字和最后的数字进行比对,发现自己有点天真,哈哈哈,又不是字符串啦,不好比较。

正确的思路就是求出它的相反的那个数,然后判断他们两是不是相等的。

负数的情况感觉应该特判一下都不是回文,没有特判也过了,下面是代码:

 1 class Solution {
 2 public:
 3     bool isPalindrome(int x) {
 4         int reverse=0;
 5         int temp=x;
 6         while(temp>0)
 7         {
 8             reverse=reverse*10+temp%10;
 9             temp=temp/10;
10         }
11         if(x==reverse)
12             return true;
13         else
14             return false;
15     }
16 };