LeetCode9. 回文数

LeetCode9. 回文数:

题目描述:

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

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

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

示例 1:

输入:x = 121

输出:true

示例 2:

输入:x = -121

输出:false

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

示例 3:

输入:x = 10

输出:false

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

提示:

-2^31 <= x <= 2^31 - 1

思路:

1.转换成字符串:翻转一下跟原来的做对比看是否一致

2.将数值进行翻转,对比是否一致

自己写的代码:

思路对了,但是做了很多冗余的判断,很慢,击败8.66%,hh

复制代码
class Solution {
public:
    bool isPalindrome(int x) {
        int res = 0;
        int temp = x;
        if(x < 0) return false;
        while(x)
        {
            if(res > (INT_MAX - x % 10) / 10) return false;
            res = res * 10 + x % 10;
            x /= 10;
        }
        printf("%d", res);
        if(res == temp) return true;
        else return false;
    }
};

转成字符串判断:

复制代码
class Solution {
public:
    bool isPalindrome(int x) {
        if(x < 0) return 0;
        string s = to_string(x);
        return s == string(s.rbegin(), s.rend());
    }
};

数值转换方法:

复制代码
class Solution {
public:
    bool isPalindrome(int x) {
        if(x < 0 ) return 0;
        int y = x;
        long long res = 0;
        while(x)
        {
            res = res * 10 + x % 10;
            x /= 10;
        }
        return res == y;
    }
};
相关推荐
智驱力人工智能25 分钟前
基于视觉分析的人脸联动使用手机检测系统 智能安全管理新突破 人脸与手机行为联动检测 多模态融合人脸与手机行为分析模型
算法·安全·目标检测·计算机视觉·智能手机·视觉检测·边缘计算
2301_764441331 小时前
水星热演化核幔耦合数值模拟
python·算法·数学建模
循环过三天1 小时前
3.4、Python-集合
开发语言·笔记·python·学习·算法
priority_key3 小时前
排序算法:堆排序、快速排序、归并排序
java·后端·算法·排序算法·归并排序·堆排序·快速排序
不染尘.4 小时前
2025_11_7_刷题
开发语言·c++·vscode·算法
来荔枝一大筐5 小时前
力扣 寻找两个正序数组的中位数
算法
算法与编程之美5 小时前
理解Java finalize函数
java·开发语言·jvm·算法
学编程就要猛5 小时前
数据结构初阶:Java中的Stack和Queue
数据结构
地平线开发者5 小时前
LLM 训练基础概念与流程简介
算法·自动驾驶
是苏浙5 小时前
零基础入门C语言之C语言实现数据结构之顺序表
c语言·开发语言·数据结构