LeetCode 7. 整数反转_leetcode整数反转-程序员宅基地

技术标签: 算法  数据结构(初阶)  leetcode  职场和发展  

整数反转


题目描述:
给你一个 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

提示:

-2^31 <= x <= 2^31 - 1
->挑战链接<-
方法一: 将整数转换位字符串在比较
题目描述很简单,但是由于考虑到x的范围问题,我们反转过后的整数有可能超出int所能存储的范围,况且题目也明确要求了,不能使用64位整型来存储;这时我们可以像字符串考虑,将输入的整数转换为字符串;字符串不存在溢出吧:然后再用字符串与字符串的比较来判断是否溢出;
首先int的范围是:-2147483648~2147483647
除去-2147483648这个点,所有值的绝对值<=2147483647对吧,也就是说当我们输入的x反转过后的绝对值如果是小于等于2147483647的那么说明我们反转过后的数据是没有发生溢出的,我们可以直接返回,如果是大于的,那么我们就直接返回0;
我们可以观察到输入的x最多有10位,反转过后也就最多有10位,加上\0,我们就需要开辟11个char类型的空间;也就是大小为11字节的char类型数组;
一个用于存放INT_MAX转换过后的字符串;//MAX
一个用于存放反转过后的X的字符串;//tmp
tmp需要先用’0’初始化,当然保证最后一个元素为\0
比如:
在这里插入图片描述
然后我们就可以利用strcmp函数比较两个字符串;
如果strcmp(MAX,tmp)<0,表示转换过后的x发生了溢出,直接返回0即可;
如果strcmp(MAX,tmp)>=0,表示转换过后未发生溢出,属于正常转换,我们把字符串转换回来就行了,同时乘以一个符号标识值(标识这个x是正数还是负数);
具体代码实现:

void reverse_(char* s)
{
    
    int left = 0;
    int right = strlen(s) - 1;
    while (left < right)
    {
    
        char tmp = s[left];
        s[left] = s[right];
        s[right] = tmp;
        left++;
        right--;
    }
}
int reverse(int x) {
    
    if (x == INT_MIN)//如果输入进来的是int类型最小值,直接返回0
        return 0;
    int flag = 1;//标识输入的x是正数还是负数,最后返回的时候还需要乘上它
    if (x < 0)
        flag = -1;
    x = abs(x);//将x转换为正数来处理
    char tmp[11] = {
     0 };//保存x反转过后的数字从最低位开始使用
    for (int i = 0; i <10; i++)//初始化临时数组;
        tmp[i] = '0';
    char MAX[11] = {
     0 };//存放INT_MAX字符串
    sprintf(MAX, "%d", INT_MAX);//将最大值转换为字符串
    sprintf(tmp,"%d",x);//先将x转换为字符串,还未反转//sprintf会自动加上\0
    int len = strlen(tmp);//计算当前数字位数
    if (len < 10)//如果长度没到到10位将该位字符改为‘0’;//确保tmp数组始终与MAX数组一样长
        tmp[len] = '0';
    reverse_(tmp);//反转字符串//得到反转过后的x所对应的字符串
    if (strcmp(MAX, tmp) < 0)//与MAX作比较
        return 0;
    int ret = atoi(tmp);//将反转过后的字符串转换为整数
    return ret * flag;//带上正负号返回
}

时间复杂度:O(N)
空间复杂度:O(1)常数个额外空间

在这里插入图片描述
方法二:
我们也可以不用转换为字符串,直接进行判断:
直接上代码:

int reverse(int x){
    
 int tmp=0;//保留个位数
 int sum=0;//存储反转过后的值
 while(x)
 {
    
     tmp=x%10;
     int prev=sum;//保留上一次sum的值
     sum=prev*10+tmp;//如果这一步执行完了,sum没发生溢出,那么我根据这个公式逆算回去:既(sum-tmp)/10==prev一定是成立的;反之,如果sum发生溢出,那么(sum-tmp)/10==prev,一定是不成立的,因此我们每次跟新一次sum,就往回算一次,看看是否能得到上一次sum的值,如果能,则说明sum没发生溢出;如果不能则说明sum发生了溢出;
     if((sum-tmp)/10!=prev)//
     return 0;
     x/=10;
 }
 return sum;
}

但是很可惜的是,使用这个方法的话,在LeetCode上跑不过去,主要是由于Leetcode对于超出范围的数据不会保存进去,而是直接报错,这就导致我们这个方法跑不过去,但是这个方法真的很棒!!!
在这里插入图片描述

在vs上可以跑:
在这里插入图片描述
时间复杂度:O(N)
空间复杂度: O (1)
方法三:
既然方法二行不通我们就另寻捷径:
我们可以这样想,既然我们不能所求的反转值,不能直接与INT_MIN、INT_MAX比较,我们可以间接的比较;

首先我们知道算反转值的公式:sum=sum10+unit;我们把上一次的反转值sum先放在prev保留一下
然后呢我们在哪prev去和INT_MAX / 10的结果比较一下,
如果prev>INT_MAX / 10,那么说明这一次计算的sum一定会溢出,我们直接返回0就可以了,
为什么?
我们现在得到的是prev>INT_MAX / 10这个条件,
那么我prev
10>INT_MAX,一定成立吧!
那么我的prev*10+unit(现在讨论的正数,unit一定也是正数)>INT_MAX;不就一定成立嘛;
举个简单例子:
INT_MAX/10=214748364;
那么我的prev=214748365,乘10就已经比我的INT_MAX大了,更何况还加个unit正数;
那么不是直接就溢出来嘛,直接返回0就可以了;
这是正数溢出的一种情况,
还有一种情况就是,prev==INT_MAX/10;
prev=214748364,那么现在我已经和INT_MAX/10相等了,在乘10,也就是2147483640然后还有加上个unit,只有当unit>=8的时候我们这一次计算的sum才会溢出,我们直接返回0就好了;
当prev<INT_MAX/10就不会有溢出现象,直接按公式计算反转值就可以了;
为什么?
prev<INT_MAX/10(214748364);
prev最大等于214748363在乘10加个unit,顶破天这次的sum等于2147483639,这不还是比
INT_MAX小,因此当prev<INT_MAX/10时,我们可以放心的计算反值,当下一次再计算反转值时,就会有prev>INT_MAX/10,会发生溢出,直接返回0;
综上正数溢出的条件:(prev>(INT_MAX/10))||((prev==INT_MAX/10)&&(unit>=(INT_MAX%10+1)))
借此读者们可以自行推导一下,负数溢出的条件;

时间复杂度:O(N)
空间复杂度:O(1)

代码实现:

int reverse(int x){
    
         int prev=0;//记录上一个反转值
         int sum=0;//记录反转值
         int unit=0;//存储个位
         while(x)
         {
    
             unit=x%10;
             prev=sum;
             if((prev>(INT_MAX/10))||((prev==INT_MAX/10)&&(unit>=(INT_MAX%10+1))))
             return 0;
             if(prev<(INT_MIN/10)||((prev==INT_MIN/10)&&(unit<=(INT_MIN%10-1))))
             return 0;
             sum=prev*10+unit;
             x/=10;
         }
         return sum;
}

在这里插入图片描述

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_62106937/article/details/127352415

智能推荐

什么是内部类?成员内部类、静态内部类、局部内部类和匿名内部类的区别及作用?_成员内部类和局部内部类的区别-程序员宅基地

文章浏览阅读3.4k次,点赞8次,收藏42次。一、什么是内部类?or 内部类的概念内部类是定义在另一个类中的类;下面类TestB是类TestA的内部类。即内部类对象引用了实例化该内部对象的外围类对象。public class TestA{ class TestB {}}二、 为什么需要内部类?or 内部类有什么作用?1、 内部类方法可以访问该类定义所在的作用域中的数据,包括私有数据。2、内部类可以对同一个包中的其他类隐藏起来。3、 当想要定义一个回调函数且不想编写大量代码时,使用匿名内部类比较便捷。三、 内部类的分类成员内部_成员内部类和局部内部类的区别

分布式系统_分布式系统运维工具-程序员宅基地

文章浏览阅读118次。分布式系统要求拆分分布式思想的实质搭配要求分布式系统要求按照某些特定的规则将项目进行拆分。如果将一个项目的所有模板功能都写到一起,当某个模块出现问题时将直接导致整个服务器出现问题。拆分按照业务拆分为不同的服务器,有效的降低系统架构的耦合性在业务拆分的基础上可按照代码层级进行拆分(view、controller、service、pojo)分布式思想的实质分布式思想的实质是为了系统的..._分布式系统运维工具

用Exce分析l数据极简入门_exce l趋势分析数据量-程序员宅基地

文章浏览阅读174次。1.数据源准备2.数据处理step1:数据表处理应用函数:①VLOOKUP函数; ② CONCATENATE函数终表:step2:数据透视表统计分析(1) 透视表汇总不同渠道用户数, 金额(2)透视表汇总不同日期购买用户数,金额(3)透视表汇总不同用户购买订单数,金额step3:讲第二步结果可视化, 比如, 柱形图(1)不同渠道用户数, 金额(2)不同日期..._exce l趋势分析数据量

宁盾堡垒机双因素认证方案_horizon宁盾双因素配置-程序员宅基地

文章浏览阅读3.3k次。堡垒机可以为企业实现服务器、网络设备、数据库、安全设备等的集中管控和安全可靠运行,帮助IT运维人员提高工作效率。通俗来说,就是用来控制哪些人可以登录哪些资产(事先防范和事中控制),以及录像记录登录资产后做了什么事情(事后溯源)。由于堡垒机内部保存着企业所有的设备资产和权限关系,是企业内部信息安全的重要一环。但目前出现的以下问题产生了很大安全隐患:密码设置过于简单,容易被暴力破解;为方便记忆,设置统一的密码,一旦单点被破,极易引发全面危机。在单一的静态密码验证机制下,登录密码是堡垒机安全的唯一_horizon宁盾双因素配置

谷歌浏览器安装(Win、Linux、离线安装)_chrome linux debian离线安装依赖-程序员宅基地

文章浏览阅读7.7k次,点赞4次,收藏16次。Chrome作为一款挺不错的浏览器,其有着诸多的优良特性,并且支持跨平台。其支持(Windows、Linux、Mac OS X、BSD、Android),在绝大多数情况下,其的安装都很简单,但有时会由于网络原因,无法安装,所以在这里总结下Chrome的安装。Windows下的安装:在线安装:离线安装:Linux下的安装:在线安装:离线安装:..._chrome linux debian离线安装依赖

烤仔TVの尚书房 | 逃离北上广?不如押宝越南“北上广”-程序员宅基地

文章浏览阅读153次。中国发达城市榜单每天都在刷新,但无非是北上广轮流坐庄。北京拥有最顶尖的文化资源,上海是“摩登”的国际化大都市,广州是活力四射的千年商都。GDP和发展潜力是衡量城市的数字指...

随便推点

java spark的使用和配置_使用java调用spark注册进去的程序-程序员宅基地

文章浏览阅读3.3k次。前言spark在java使用比较少,多是scala的用法,我这里介绍一下我在项目中使用的代码配置详细算法的使用请点击我主页列表查看版本jar版本说明spark3.0.1scala2.12这个版本注意和spark版本对应,只是为了引jar包springboot版本2.3.2.RELEASEmaven<!-- spark --> <dependency> <gro_使用java调用spark注册进去的程序

汽车零部件开发工具巨头V公司全套bootloader中UDS协议栈源代码,自己完成底层外设驱动开发后,集成即可使用_uds协议栈 源代码-程序员宅基地

文章浏览阅读4.8k次。汽车零部件开发工具巨头V公司全套bootloader中UDS协议栈源代码,自己完成底层外设驱动开发后,集成即可使用,代码精简高效,大厂出品有量产保证。:139800617636213023darcy169_uds协议栈 源代码

AUTOSAR基础篇之OS(下)_autosar 定义了 5 种多核支持类型-程序员宅基地

文章浏览阅读4.6k次,点赞20次,收藏148次。AUTOSAR基础篇之OS(下)前言首先,请问大家几个小小的问题,你清楚:你知道多核OS在什么场景下使用吗?多核系统OS又是如何协同启动或者关闭的呢?AUTOSAR OS存在哪些功能安全等方面的要求呢?多核OS之间的启动关闭与单核相比又存在哪些异同呢?。。。。。。今天,我们来一起探索并回答这些问题。为了便于大家理解,以下是本文的主题大纲:[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JCXrdI0k-1636287756923)(https://gite_autosar 定义了 5 种多核支持类型

VS报错无法打开自己写的头文件_vs2013打不开自己定义的头文件-程序员宅基地

文章浏览阅读2.2k次,点赞6次,收藏14次。原因:自己写的头文件没有被加入到方案的包含目录中去,无法被检索到,也就无法打开。将自己写的头文件都放入header files。然后在VS界面上,右键方案名,点击属性。将自己头文件夹的目录添加进去。_vs2013打不开自己定义的头文件

【Redis】Redis基础命令集详解_redis命令-程序员宅基地

文章浏览阅读3.3w次,点赞80次,收藏342次。此时,可以将系统中所有用户的 Session 数据全部保存到 Redis 中,用户在提交新的请求后,系统先从Redis 中查找相应的Session 数据,如果存在,则再进行相关操作,否则跳转到登录页面。此时,可以将系统中所有用户的 Session 数据全部保存到 Redis 中,用户在提交新的请求后,系统先从Redis 中查找相应的Session 数据,如果存在,则再进行相关操作,否则跳转到登录页面。当数据量很大时,count 的数量的指定可能会不起作用,Redis 会自动调整每次的遍历数目。_redis命令

URP渲染管线简介-程序员宅基地

文章浏览阅读449次,点赞3次,收藏3次。URP的设计目标是在保持高性能的同时,提供更多的渲染功能和自定义选项。与普通项目相比,会多出Presets文件夹,里面包含着一些设置,包括本色,声音,法线,贴图等设置。全局只有主光源和附加光源,主光源只支持平行光,附加光源数量有限制,主光源和附加光源在一次Pass中可以一起着色。URP:全局只有主光源和附加光源,主光源只支持平行光,附加光源数量有限制,一次Pass可以计算多个光源。可编程渲染管线:渲染策略是可以供程序员定制的,可以定制的有:光照计算和光源,深度测试,摄像机光照烘焙,后期处理策略等等。_urp渲染管线

推荐文章

热门文章

相关标签