回文数

题目

  • 判断一个整数是否是回文数。回文数是指正序(从左到右)和倒序(从右到左)读都是一样的整数

  • 示例 1:

输入: 121
输出: true
示例 2:

输入: -121
输出: false
解释: 从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。
示例 3:

输入: 10
输出: false
解释: 从右向左读, 为 01 。因此它不是一个回文数。

  • 进阶

不使用整数转换字符串解决这个问题

  • 思路
    (1)既然不让我们使用字符串,那么我们就应该直接对其进行转换
    (2)负数永远不可能是一个回文数
    (3)当这个数大于等于0的时候可以继续执行

举例一个整数123
(1)取其个位数3
(2)将原数据123,缩小10倍,变为12
(3)将取到的个位数3扩大10倍,3*10=30
(4)重复过程,直至原数据变为1,新产生的数据为320
(5)此时只用将320 + 1 = 321,这个就是原数据的倒序数据

  • 代码实现
package com.xiyou.solutio;

/**
 * 判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。
 *
 * 示例 1:
 *
 * 输入: 121
 * 输出: true
 * 示例 2:
 *
 * 输入: -121
 * 输出: false
 * 解释: 从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。
 * 示例 3:
 *
 * 输入: 10
 * 输出: false
 * 解释: 从右向左读, 为 01 。因此它不是一个回文数。
 * 进阶:
 *
 * 你能不将整数转为字符串来解决这个问题吗?
 */
public class HuiWenShu {
    public boolean isPalindrome(int x) {
        if (x < 0) {
            // 小于0 的肯定不是回文
            return false;
        }
        // 求传入参数的绝对值 用来保存原值
        int absNum = x;
        // 存储原数据的个位数
        int singleNum = 0;
        // 用来存储临时数据
        int tmpNum = 0;
        // 遍历传进来的参数
        // 当值大于等于10 的时候,才会进循环
        while (absNum >= 10) {
            // 取当前的个位数
            singleNum = absNum % 10;
            // 数据除以10 去掉个位 将三位变两位等 比如321 变 32
            absNum = absNum / 10;
            // 加上刚刚得到的个位数 * 10
            tmpNum = (tmpNum + singleNum) * 10;
        }
        // 还差一个个位数没有加上 此时的tmpNum就是原数字的倒序数字
        tmpNum += absNum;
        if (x - tmpNum == 0) {
            // 如果该数字与原数据相等
            return true;
        }
        return false;
    }

    public static void main(String[] args) {
        HuiWenShu huiWenShu = new HuiWenShu();
        boolean palindrome = huiWenShu.isPalindrome(-2147483648);
        System.out.println(palindrome);
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值