题目大意:
回文数
判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。
示例 1:
输入: 121 输出: true
示例 2:
输入: -121 输出: false 解释: 从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。
示例 3:
输入: 10 输出: false 解释: 从右向左读, 为 01 。因此它不是一个回文数。
进阶:
你能不将整数转为字符串来解决这个问题吗?
如果想查看本题目是哪家公司的面试题,请参考以下免费链接: https://leetcode.jp/problemdetail.php?id=9
解题思路分析:
题目要求不能使用字符串来解题,那么我们就需要找到数字上每一位的方法。之前文章我们多次提到过,求数字上每一位的方法,即使用当前数字与10求余数,该余数即是当前数字最低位上的数字,接下来我们将当前数字除以10,继续求它与10的余数,该数字即是次低位上的数字,重复上述过程直到当前数字为0为止。
另外判断回文的方式也不难,我们采用剥洋葱的方式从最外层向内比较,解题时可以定义左右两个指针,初始时左指针指向下标0,右指针指向末尾,如果当前俩指针指向的值不一致,直接返回false。反之,左指针加一,右指针减一,继续比较,重复此过程直到左指针不再小于右指针为止。
实现代码:
public boolean isPalindrome(int x) { if(x<0) return false; // 保存x上每一位的数 List<Integer> list = new ArrayList<>(); // 取得x上的每一位 while(x>0){ list.add(x%10); x/=10; } // 定义左右指针 int left=0,right=list.size()-1; while(left<right){ // 左右指针指向的数字不同时,返回false if(list.get(left) != list.get(right)){ return false; } left++; right--; } return true; }
本题解法执行时间为8ms。
Runtime: 8 ms, faster than 40.92% of Java online submissions for Palindrome Number.
Memory Usage: 40.6 MB, less than 5.02% of Java online submissions for Palindrome Number.
本网站文章均为原创内容,并可随意转载,但请标明本文链接如有任何疑问可在文章底部留言。为了防止恶意评论,本博客现已开启留言审核功能。但是博主会在后台第一时间看到您的留言,并会在第一时间对您的留言进行回复!欢迎交流!
本文链接: https://leetcode.jp/leetcode-9-palindrome-number-解题思路分析/