Leetcode之PHP版题目解析(9. Palindrome Number)
2019-4-8 星期一 开始吧
上一题链接 Leetcode之PHP版题目解析(234. Palindrome Linked List)
题目描述
基于上一题判断是否是回文链表,这题判断是否是一个回文数.
题目分析
基础的解法,首先负数是不可能是回文数字的.如果是回文数字,那么把当前的数反向之后还是和原来的数相等的.
具体实现1
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部分,如果数字的长度是奇数位的话,作为一个回文数,数字正中间的位上的数字是不需要进行比较的(自己等于自己),所以需要去掉.
Github整理地址:https://github.com/wuqinqiang/leetcode-php
No Comments