数学 - 回文数字巧解[E]

优质
小牛编辑
151浏览
2023-12-01

009. Palindrome Number[E]

问题:

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

思路

这里说不用额外的空间意思是不用O(n)的空间,O(1)的还是可以用的,不然循环都不好写。。

思路1

简单的思路 就是把数字逆转,然后判断逆转后的数字跟原来数字是不是一样的。

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

思路2

但是其实,不用把数字逆转完再判断,因为如果是回文数字,那么只要逆转一半看是否满足回文条件就行了。

设新数为r,原来数为x,每次:

  1. x = x/10,r = r*10 + x%10;
  • 如何到一半停止?

    • 如果x <= r时可以停止了(至少到了一半)
    • 如果是偶数长度,并且是回文,那么刚好可以到x == r
    • 如果为奇数长度,并且是回文,那么x < r,这时候r刚好比x多一位数
  • 停止后判断是否是回文

    • 如果是偶数长度,很简单判断 r == x
    • 如果是奇数长度,要判断 r/10 == x

注意:这里有一些小问题。

  • 当尾数为0的情况。尾数为0会导致r的增长少1位数(因为0*10 = 0)。
    比如110不是回文,最后停止r = 1 x =1 但是 r == x
  • 当数字小于0的时候,也是不满足回文的条件的。
  1. class Solution {
  2. public:
  3. bool isPalindrome(int x) {
  4. if(x < 0 || (x != 0 && x %10 ==0)) return false;
  5. int r = 0;
  6. while(x > r)
  7. {
  8. r =r*10 + x%10;
  9. x /=10;
  10. }
  11. return (r == x) || (r/10 == x);
  12. }
  13. };