Skip to content

Latest commit

 

History

History
63 lines (54 loc) · 2.07 KB

9.md

File metadata and controls

63 lines (54 loc) · 2.07 KB

✏️Leetcode之PHP版题目解析(9. Palindrome Number)

2019-04-08 吴亲库里 库里的深夜食堂


✏️描述

判断是否是一个回文数.


✏️题目实例

****

✏️题目分析

基础的解法,首先负数是不可能是回文数字的.如果是回文数字,那么把当前的数反向之后还是和原来的数相等的.


✏️解法一

    function isPalindrome($x) {
           if($x<0){
               return false;
           }
           $back=0;$index=$x;
           while($x){
               $back=$back*10+$x%10;
               $x=intval(floor($x/10));
           }
           if($back==$index) {
               return true;
           }else {
               return false;
           }
       }

✏️解法二

除了负数不是回文数以外,如果数字以0结尾的也不可能是回文数,尾数是0最高位可没有0和你配对(当然数字是0的话它是回文数),如果是回文数,那么他左半部分和右半部分的反转是一样的.所以我们只需要反转数字的右半部分进行比较即可.

递归

  function isPalindrome($x) {
          if($x<0 || $x%10==0 && $x !=0){
              return false;
          }
          $backNumber=0;
          while($x>$backNumber){
              $backNumber=$backNumber*10+$x%10;
              $x =intval(floor($x/10));
          }
          return $x==$backNumber || $x==intval(floor($backNumber /10));
      }
   

最后return部分,如果数字的长度是奇数位的话,作为一个回文数,数字正中间的位上的数字是不需要进行比较的(自己等于自己),所以需要去掉.

联系