LeetCode初级算法之字符串:7 整数反转
整数反转
题目地址:https://leetcode-cn.com/problems/reverse-integer/
给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。
示例 1:
输入: 123
输出: 321
示例 2:
输入: -123
输出: -321
示例 3:
输入: 120
输出: 21
注意:
假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为 [−2^31, 2^31 − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。
解法一:暴力解法
主体
整数转字符串
字符串的反转
字符串转整数
边界
- 数值溢出边界:溢出返回0
细节
- 首位不为0
- 符号处理
public int reverse(int x) {
//1.整数转字符串
String str = "" + x;
char[] s = str.toCharArray();
//2.字符串的反转
int n = s.length;
for(int i = 0; i < n/2; i++){
char temp = s[i];
s[i] = s[n-i-1];
s[n-i-1] = temp;
}
//3.字符串转整数
//Integer result = Integer.valueOf(String.valueOf(array));
long value = Long.valueOf(String.valueOf(array));
boolean b = value > Integer.MAX_VALUE || value < Integer.MIN_VALUE;
int result = b ? 0 : (int)value;
return result;
}
在上述代码中已经完成主体代码以及反转后的数值越出边界的问题,首位不为零问题:Integer将整数字符串转整数时会自动去掉前面如果有高位的0。那么还剩下符号处理整数x如果是-123,反转字符串是"321-"肯定是不能的。要把负号拿出来之后的数字参与主体过程,最后再把结果加上负号。
//拿走符号sign
int sign = x > 0 ? 1 : -1;
//剩下绝对值
x = x < 0 ? x * -1 : x;
让处理之后的x参与主体代码,最后返回值加上符号
return result * sign;
但上面拿绝对值的这个步骤是有问题的,因为最小值的绝对值是比最大值要大1的。当传入的int x = Integer.MIN_VALUE时绝对值超过了int的范围。因此在符号拿取之前先进行判断,把极值(包括最大值)直接返回掉毕竟它们反转之后数字大小一定是溢出没必要经过主体三步之后在判断是否返回0。
public int reverse(int x) {
//极值筛掉
if(x == Integer.MAX_VALUE || x == Integer.MIN_VALUE){
return 0;
}
//符号处理
int sign = x > 0 ? 1 : -1;
x = x < 0 ? x * -1 : x;
//1.整数转字符串
String str = "" + x;
char[] s = str.toCharArray();
//2.字符串的反转
int n = s.length;
for(int i = 0; i < n/2; i++){
char temp = s[i];
s[i] = s[n-i-1];
s[n-i-1] = temp;
}
//3.字符串转整数
//Integer result = Integer.valueOf(String.valueOf(array));
long value = Long.valueOf(String.valueOf(s));
boolean b = value > Integer.MAX_VALUE || value < Integer.MIN_VALUE;
int result = b ? 0 : (int)value;
//加上符号
return result * sign;
}
时间复杂度O(n),空间复杂度O(n)
解法二:数学思维
既然是把一个整数变成另外一个整数面对这样的问题的完全可以找到数学的方式,在数组里我们使用索引指针取各个值,在数字里面我们就可以用除法和取模运算来获取各个值。上面我们数组或者字符串直接拼接各个字符。这里我们就累加拼接。效率提升一个次元。
public int reverse(int x) {
//极值筛掉
if(x == Integer.MAX_VALUE || x == Integer.MIN_VALUE){
return 0;
}
int result = 0;//返回结果
int last = 0;//末位
while((last = x % 10) != x){
result = result * 10 + last;
x /= 10;
}
//添加最后一位判断溢出
long value = result;
value = value * 10 + last;
if(value > Integer.MAX_VALUE || value < Integer.MIN_VALUE){
return 0;
}else{
result = (int)value;
}
return result;
}
时间复杂度O(n),空间复杂度O(1)
总结
总体上是两种思路但可以优化的点还有一些比如个位判断直接返回等等,这里主要体会的是关于数字处理的相关算法都是可以采用数学方式,它是远远比操作字符效率要高。第二就是关于实现主体与细节、边界的一个划分,尽量降低耦合性。
LeetCode初级算法之字符串:7 整数反转的更多相关文章
- LeetCode初级算法之字符串:344 反转字符串
反转字符串 题目地址:https://leetcode-cn.com/problems/reverse-string/ 编写一个函数,其作用是将输入的字符串反转过来.输入字符串以字符数组 char[] ...
- 算法练习LeetCode初级算法之字符串
反转字符串 我的解法比较low,利用集合的工具类Collections.reverse反转,用时过长 class Solution { public void reverseString(char[] ...
- LeetCode初级算法之字符串:387 字符串中的第一个唯一字符
字符串中的第一个唯一字符 题目地址:https://leetcode-cn.com/problems/first-unique-character-in-a-string/ 给定一个字符串,找到它的第 ...
- LeetCode初级算法之字符串:242 有效的字母异位词
有效的字母异位词 题目地址:https://leetcode-cn.com/problems/valid-anagram/ 给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位 ...
- 【LeetCode算法】LeetCode初级算法——字符串
在LeetCode初级算法的字符串专题中,共给出了九道题目,分别为:反转字符串,整数反转,字符串中的第一个唯一字符,有效的字母异位词,验证回文字符串,字符串转换整数,实现strStr(),报数,最 ...
- LeetCode初级算法--字符串01:反转字符串
LeetCode初级算法--字符串01:反转字符串 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.ne ...
- LeetCode初级算法的Python实现--字符串
LeetCode初级算法的Python实现--字符串 # 反转字符串 def reverseString(s): return s[::-1] # 颠倒数字 def reverse(x): if x ...
- LeetCode初级算法--链表01:反转链表
LeetCode初级算法--链表01:反转链表 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.net/ ...
- LeetCode初级算法--字符串02:字符串中的第一个唯一字符
LeetCode初级算法--字符串02:字符串中的第一个唯一字符 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog. ...
随机推荐
- Javascript 参数传递
又一个基本概念出问题,参数传递都是值传递, var a={x:10} function test(obj){obj=1} test(a) console.log(a) 输出什么,如果你说1,那就错了, ...
- 企业网络拓扑RSTP功能实例
组网图形 RSTP简介 以太网交换网络中为了进行链路备份,提高网络可靠性,通常会使用冗余链路.但是使用冗余链路会在交换网络上产生环路,引发广播风暴以及MAC地址表不稳定等故障现象,从而导致用户通信质 ...
- linux netfilter 五个钩子点
参考http://www.linuxtcpipstack.com/685.html#NF_INET_PRE_ROUTING https://opengers.github.io/openstack/o ...
- Golang 接口型函数和http.Handler接口
一.接口型函数 参考Golang必备技巧:接口型函数 1.原始接口实现 type Handler interface { Do(k, v interface{}) } func Each(m map[ ...
- 使用 ffmpeg 命令直播推流
CMD使用到的命令 D: -> 表示进入D盘cd /live -> 表示进入某个路径 执行条件 1.ffmpeg.exe 与视频放在同一目录下,纯英文目录2.执行以上命令进入到ffmpeg ...
- 源码分析:CountDownLatch 之倒计时门栓
简介 CountDownLatch 是JDK1.5 开始提供的一种同步辅助工具,它允许一个或多个线程一直等待,直到其他线程执行的操作完成为止.在初始化的时候给定 CountDownLatch 一个计数 ...
- Cassandra + JSON?答案就是Stargate Documents API
JSON已经被开发者在很多场景中频繁使用,但是其实将Cassandra用于JSON或其他面向文档的用例并不容易. 为了让开发者在使用原生的JSON的同时还能享受Cassandra带来的可靠性和伸缩性, ...
- Poem Codes - 攻防世界(Decrypt-the-Message)
Poem Codes Poem Code 最显著的特点就是一首诗歌. 详情请戳这里 让我们一起来过滤一遍这个神奇的加密过程~ ① 给出一首诗歌 for my purpose holds to sail ...
- 如何使用ABBYY FineReader 手动管理文档区域
在运用OCR编辑器时,ABBYY FineReader 15(Windows系统)OCR文字识别软件会对扫描仪或数码相机导入的图像进行识别和检测.在识别和检测之前,软件会自动对PDF文档中的文本.图片 ...
- 对于AQS的理解
1.JUC包中的 CountDownLatch.CyclicBarrier.ReentrantLock和Semaphore都是基于AQS(AbstractQuenedSynchronizer)实现的 ...