Leetcode - 回文数 E[9]

  • 问题描述:
给你一个整数 x ,如果 x 是一个回文整数,返回 true ;否则,返回 false 。
回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。例如,121 是回文,而 123 不是。

示例 1:
        输入:x = 121
        输出:true

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

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

示例 4:
        输入:x = -101
        输出:false

提示:-231 <= x <= 231 - 1

 解决方法:

        1.  将数字转换为 字符数组 然后通过循环判断数字是否是回文数

        2.  得到给定数字的反转数,然后判断是否与原数相同(得到的数字有超出范围的可能)

        3.  将给定的数字反转一般,通过一个变量存储,然后判断是否相同

方法1:

        将数字转换成字符数组然后判断一下就行了

        代码:

        

        if(x < 0 || (x % 10 == 0 && x != 0)){
            return false;
        }

        String value = String.valueOf(x);
        char[] chars = value.toCharArray();
        int length = chars.length;

        for(int i = 0;i < length / 2;i++){
            if(chars[i] != chars[length - i -1]){
                return false;
            }
        }
        return true;
    

        运行结果:

        

 方法二:

        将给定的数字反转,得到反转的数字并于原数字就行判断

        至于高效率反转整数可以参考我的另一篇文章:

https://blog.csdn.net/Lagi_lanumoa/article/details/120004471

         代码:

        if(x < 0 || (x % 10 == 0 && x != 0)){
            return false;
        }
        int rev = 0;

        int Max = (int) (Math.pow(2,31) - 1);
        int Min = -(Max + 1);

        int number = x;

        int end;

        /* 反转全部数字 */
        while(number != 0){
            if(rev < (Min / 10) || rev > (Max / 10)){
                return false;
            }
            end = number % 10;
            number /= 10;
            rev = rev * 10 + end;
        }
        return rev == x;

         运行结果:

                

方法三:

         方法和方法2有些类似,我们将给定数字的一般进行反转,然后判断与原数字是否相同,当然原数字也要跟着变化。

                                                x 为给定判断是否是回文数的数字

                         x                             reverted Number
                12321                        0
                1232                        1
                123                        12
                12                        123

               

由上图可以看到,当 reverted Number >= x 是结束循环,得到需要的反转数,同时有以下两种情况:

        1. reverted Number = x

        2. reverted Number > x,这个时候对reverted Number 处理以下然后与 x 进行判断就能得到我们需要的结果。

        

        代码:

        if(x < 0 || (x % 10 == 0 && x != 0)){
            return false;
        }
        
        int rev = 0;
        int end;

        while( x > rev ){
            end = x % 10;
            x /= 10;
            rev = rev * 10 + end;
        }

        if(x < rev){
            rev /= 10;
        }

        return x == rev;

                 运行结果:

 PS:给个赞呗!😊

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
根据提供的引用内容,有三种方法可以解决LeetCode上的最长回文子串问题。 方法一是使用扩展中心法优化,即从左向右遍历字符串,找到连续相同字符组成的子串作为扩展中心,然后从该中心向左右扩展,找到最长的回文子串。这个方法的时间复杂度为O(n²)。\[1\] 方法二是直接循环字符串,判断子串是否是回文子串,然后得到最长回文子串。这个方法的时间复杂度为O(n³),效率较低。\[2\] 方法三是双层for循环遍历所有子串可能,然后再对比是否反向和正向是一样的。这个方法的时间复杂度也为O(n³),效率较低。\[3\] 综上所述,方法一是解决LeetCode最长回文子串问题的最优解法。 #### 引用[.reference_title] - *1* [LeetCode_5_最长回文子串](https://blog.csdn.net/qq_38975553/article/details/109222153)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Leetcode-最长回文子串](https://blog.csdn.net/duffon_ze/article/details/86691293)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [LeetCode 第5题:最长回文子串(Python3解法)](https://blog.csdn.net/weixin_43490422/article/details/126479629)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

最向往的地方

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值