1_9. 回文数

9. 回文数

  • 难度: 简单

  • 提示:

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

    回文数

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

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

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

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

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

提示: 截图

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

代码实现

java 复制代码
class Solution {
    public boolean isPalindrome(int x) {
        
        if (x<0){
            return false;
        }

        int temp=x, reverse=0;
        while(temp>0){
            reverse=reverse*10+temp%10;
            temp/=10;
        }
        return reverse==x;

    }
}

当时思路

  • 首先先剔除小于零的情况, 直接返回false
  • 大于等于零的情况时: 使用对10取余除, 再除10, 可以得到每一个 位上的数字, 然后使用乘10再相加, 可以得到一个反转后的数字, 然后判断前后两个数是否相等, 相等就说明是回文数.

进阶 代码实现

  • 使用整数转为字符串来解决这个问题
java 复制代码
class Solution {
    public boolean isPalindrome(int x) {
        
        String strNumber=Integer.toString(x);
        if (x<0){
            return false;
        }else if(x>=0&&x<10){
            return true;
        }
        for (int i = 0,j=strNumber.length()-1; i <j ; i++,j--) {
            if (strNumber.charAt(i)!=strNumber.charAt(j)){
                return false;
            }
        }
        return true;

    }
}

  • 到此教程就结束了.
  • 转载: 请附上本文链接.
  • 如果文章对你有帮助, 可以点赞收藏一下, 以防下次需要可以快速找到.
相关推荐
gfdhy1 小时前
【c++】哈希算法深度解析:实现、核心作用与工业级应用
c语言·开发语言·c++·算法·密码学·哈希算法·哈希
百***06011 小时前
SpringMVC 请求参数接收
前端·javascript·算法
一个不知名程序员www2 小时前
算法学习入门---vector(C++)
c++·算法
云飞云共享云桌面2 小时前
无需配置传统电脑——智能装备工厂10个SolidWorks共享一台工作站
运维·服务器·前端·网络·算法·电脑
福尔摩斯张2 小时前
《C 语言指针从入门到精通:全面笔记 + 实战习题深度解析》(超详细)
linux·运维·服务器·c语言·开发语言·c++·算法
橘颂TA3 小时前
【剑斩OFFER】算法的暴力美学——两整数之和
算法·leetcode·职场和发展
xxxxxxllllllshi3 小时前
【LeetCode Hot100----14-贪心算法(01-05),包含多种方法,详细思路与代码,让你一篇文章看懂所有!】
java·数据结构·算法·leetcode·贪心算法
前端小L3 小时前
图论专题(二十二):并查集的“逻辑审判”——判断「等式方程的可满足性」
算法·矩阵·深度优先·图论·宽度优先
铁手飞鹰4 小时前
二叉树(C语言,手撕)
c语言·数据结构·算法·二叉树·深度优先·广度优先
专业抄代码选手5 小时前
【Leetcode】1930. 长度为 3 的不同回文子序列
javascript·算法·面试