整数反转算法(leetcode第7题)

题目描述:

复制代码
给你一个 32 位的有符号整数 x ,返回将 x 中的数字部分反转后的结果。

如果反转后整数超过 32 位的有符号整数的范围 [−231,  231 − 1] ,就返回 0。

假设环境不允许存储 64 位整数(有符号或无符号)。
 

示例 1:

输入:x = 123
输出:321
示例 2:

输入:x = -123
输出:-321
示例 3:

输入:x = 120
输出:21
示例 4:

输入:x = 0
输出:0
 

提示:

-231 <= x <= 231 - 1

算法:

思路:

依次取每位数反转,与最大最小值进行比较

代码实现:
cpp 复制代码
int reverse(int x) {
    int rev = 0;
    while (x != 0) {
        if (rev < INT_MIN / 10 || rev > INT_MAX / 10) {
            return 0;
        }
        int digit = x % 10;
        x /= 10;
        rev = rev * 10 + digit;
    }
    return rev;
}
相关推荐
gihigo19982 小时前
MATLAB数值分析方程求解方法详解
算法·机器学习·matlab
程序员buddha5 小时前
C语言数组详解
c语言·开发语言·算法
蒙奇D索大7 小时前
【算法】递归算法的深度实践:从布尔运算到二叉树剪枝的DFS之旅
笔记·学习·算法·leetcode·深度优先·剪枝
卡提西亚7 小时前
C++笔记-25-函数模板
c++·笔记·算法
ghie90907 小时前
MATLAB/Simulink水箱水位控制系统实现
开发语言·算法·matlab
多多*8 小时前
分布式系统中的CAP理论和BASE理论
java·数据结构·算法·log4j·maven
yuan199978 小时前
基于粒子群优化(PSO)算法的PID控制器参数整定
算法
程序员三藏8 小时前
快速弄懂POM设计模式
自动化测试·软件测试·python·selenium·测试工具·设计模式·职场和发展
小白程序员成长日记8 小时前
2025.11.10 力扣每日一题
数据结构·算法·leetcode
hoiii1878 小时前
基于交替方向乘子法(ADMM)的RPCA MATLAB实现
人工智能·算法·matlab