zoukankan      html  css  js  c++  java
  • 回文数

    需求

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

    示例

        

    解题

      我自己只想到了两种方法,在参考官方给出的方法后,也了解了第三种方法。

      方法一:将全部数字反转,然后对比即可。

        // 解法一:全部数字反转法
        // 思路:通过递归取模得到该数的翻转数,进行对比
        public static boolean isPalindrome(int x) {
            if (x < 0 || (x % 10 == 0 && x != 0)) {
                return false;
            } else if (0 <= x && x < 10) {
                return true;
            }
            long inputNum = x;
    
            long newNum = 0;
            while (x > 0) {
                int mod = x % 10;
                x = x / 10;
                newNum = newNum * 10 + mod;
            }
            return inputNum == newNum;
        }

      方法二:字符串反转法,通过jdk自带API实现,最优雅。

        // 解法二:字符串翻转法
        // 思路:使用StringBuilder常用的API即可
        public static boolean isPalindrome2(int x) {
            return new StringBuilder(String.valueOf(x)).reverse().toString().equals(String.valueOf(x));
        }

      方法三:只反转一半数字法。核心的关键是怎么判断该数字只反转了一半,大家可以看下代码上的思路

        //   解法三:只反转一半的数字
        //   思路:给一个官方的解释说明,我觉得解释已经很清楚了。对于数字 1221,如果执行 1221 % 10,我们将得到最后一位数字 1,
    // 要得到倒数第二位数字,我们可以先通过除以 10 把最后一位数字从 1221 中移除,1221 / 10 = 122,再求出上一步结果除以 10 的余数,122 % 10 = 2,
    // 就可以得到倒数第二位数字。如果我们把最后一位数字乘以 10,再加上倒数第二位数字,1 * 10 + 2 = 12,就得到了我们想要的反转后的数字。
    // 如果继续这个过程,我们将得到更多位数的反转数字。现在的问题是,我们如何知道反转数字的位数已经达到原始数字位数的一半?
    // 我们将原始数字除以 10,然后给反转后的数字乘上 10,所以,当原始数字小于反转后的数字时,就意味着我们已经处理了一半位数的数字。
    // public static boolean isPalindrome3(int x) { if (x < 0 || (x % 10 == 0 && x != 0)) { return false; } else if (0 <= x && x < 10) { return true; } int revertedNumber = 0; while (x > revertedNumber) { revertedNumber = revertedNumber * 10 + x % 10; if (revertedNumber != x) { x /= 10; } } return x == revertedNumber; }

    参考:力扣(LeetCode)

  • 相关阅读:
    Speex for Android
    反射(高大上)、类的内置方法
    hashlib摘要算法模块,logging日志,configparser配置文件模块
    抽象类,接口类,封装,property,classmetod,statimethod
    面对对象三大特征:继承 多态(鸭子类型)(面试题)
    面向对象命名空间及组合(面试题)
    初始面向对象
    模块与包
    常用模块
    列表表达式,生成器表达式,
  • 原文地址:https://www.cnblogs.com/maguanyue/p/12740025.html
Copyright © 2011-2022 走看看