回文数
文章目录
【注意】最后更新于 May 11, 2022,文中内容可能已过时,请谨慎使用。
回文数
题目
判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。
示例 1:
输入: 121 输出: true 示例 2:
输入: -121 输出: false 解释: 从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。 示例 3:
输入: 10 输出: false 解释: 从右向左读, 为 01 。因此它不是一个回文数。 进阶:
你能不将整数转为字符串来解决这个问题吗?
来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/palindrome-number 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解题方法
- 将 后半段数字进行反转,与前半段比较。
- 通过 x%10 得到末位的值。
- 将末位的值加到反转的值;revertedNumber = revertedNumber * 10 + x % 10
- 通过 x/10 得到末位之外的值。
- 循环上面操作,直到 x<=revertedNumber ,此时数字对半了。
- 最后判断奇偶数位:
- 偶数位:直接判断 x是否等于 revertedNumber 。
- 奇数位:最中间的数字在 revertedNumber 的最后一位,判断 x 是否等于 revertedNumber/10 。
|
|
文章作者 Mazy
上次更新 2022-05-11