【leetcode算法从入门到精通】9. 回文数

寒门立志,向来九死一生。

题目

感觉leetcode按题库顺序刷还是对新手太不友好了,到第5题就折戟沉沙了。还是先过滤一下难度吧。

给你一个整数 x ,如果 x 是一个回文整数,返回 true ;否则,返回 false 。

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

例如,121 是回文,而 123 不是。

示例 1:

输入:x = 121

输出:true

示例 2:

输入:x = -121

输出:false

解释:从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。

示例 3:

输入:x = 10

输出:false

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

提示:

-231 <= x <= 231 - 1

进阶:你能不将整数转为字符串来解决这个问题吗?

分析

直接就是一个暴力解法,输入一个整数,把整数的每个位的数按顺序放到ListA中,然后倒着顺序放到ListB中,从第一个数字还是比较,看是否相等。(直接逆序的方法暂时不会,一会查查)。

复制代码
class Solution {
    public boolean isPalindrome(int x) {
          // 如果x是一个负数,那么他不是回文数
        if (x < 0) {
            return false;
        }
        // 把x逆序,然后比较数组每一位是否相等
        String xStr = String.valueOf(x);
        char[] xChars = xStr.toCharArray();
        List<Character> reXChars=new ArrayList<>();
        for (int i = xChars.length - 1; i >= 0; i--) {
            reXChars.add(xChars[i]);
        }
        for (int i=0;i<reXChars.size();i++){
            if (!reXChars.get(i).equals(xChars[i])){
                return false;
            }
        }
        return true;
    }
}

结果

看完解析的优化版本

复制代码
class Solution {
    public boolean isPalindrome(int x) {
        // 12221
        // 如果x是一个负数,那么他不是回文数
        // 如果个位是0,那么第一位也得是0,整数中满足条件的只有0
        if (x < 0 || (x % 10 == 0 && x != 0)) {
            return false;
        }
        // 如何求数字的逆序数字
        int revertedNumber = 0;
        while (x > revertedNumber) {
            revertedNumber = revertedNumber * 10 + x % 10;
            x /= 10;
        }

        return x == revertedNumber || x == revertedNumber / 10;
    }
}

问题

1.int怎么逆序也不会

例子:1221

%10 求最小位数字(1),/10 再% 求倒数第二位数字(2),重复可以倒着取出所有数字;

倒序取2次是,12 ,是通过第一位 *10 +第二位 计算得出

倒序取3次,122,是通过(第一位 *10 +第二位)*10 +第三位得出

相关推荐
海清河晏11122 分钟前
数据结构 | 单循环链表
数据结构·算法·链表
wuweijianlove4 小时前
算法性能的渐近与非渐近行为对比的技术4
算法
_dindong5 小时前
cf1091div2 C.Grid Covering(数论)
c++·算法
AI成长日志5 小时前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
黎阳之光5 小时前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
skywalker_115 小时前
力扣hot100-3(最长连续序列),4(移动零)
数据结构·算法·leetcode
6Hzlia5 小时前
【Hot 100 刷题计划】 LeetCode 17. 电话号码的字母组合 | C++ 回溯算法经典模板
c++·算法·leetcode
wfbcg6 小时前
每日算法练习:LeetCode 209. 长度最小的子数组 ✅
算法·leetcode·职场和发展
_日拱一卒6 小时前
LeetCode:除了自身以外数组的乘积
数据结构·算法·leetcode
计算机安禾6 小时前
【数据结构与算法】第36篇:排序大总结:稳定性、时间复杂度与适用场景
c语言·数据结构·c++·算法·链表·线性回归·visual studio