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. ...
随机推荐
- VBA_headers_mapping
Header Mapping--应对 Report Headers 的变化 Author : Collin_PXY 背景 在 RPA工作中,稳定的规则非常重要,因为 RPA项目就是基于规则而进行的,但 ...
- tcp 拥塞控制引擎&状态机
TCP核心:流量控制 拥塞控制 流量控制:滑动窗口来实现, 防止接收方能够处理过来 拥塞控制:防止过多的包被发送到网络中,避免出现网络负载过大 说一说 拥塞控制: 拥塞控制状态机的状态有五种,分别 ...
- Netlink 内核实现分析 4
netlink 库函数: http://www.infradead.org/~tgr/libnl/doc/core.html#core_netlink_fundamentals #define NET ...
- 通过lseek产生空洞文件
//off_t lseek(int fd,off_t offset, int base) 偏移量 搜索的起始位置(文件头(SEEK_SET),当前指针位置(SEEK_CUR),文件尾(SEEK_END ...
- struts.xml中的配置内容
一些常量的配置 包标签 拦截器标签(自定义拦截器,拦截器栈) //对待拦截器栈与拦截器是一样的,只是标签不同而已. global-results标签 action标签:拦截器标签,resu ...
- 使用XSL解析XML输出HTML(XSL学习笔记一)
最近项目用到 XSL + XML,XML大家应该很熟悉,XSL暂且不解释,先看效果,如果想学习XSL的内容,可以先访问: https://www.w3school.com.cn/xsl/xsl_lan ...
- Java 的反射机制你了解多少?
不知道多少次听说过了Java反射机制的使用,比如:Spring 框架如何实例化IoC容器中的Bean,编码过程中如何动态的清理对象中的字段信息等等.工作中只是听说.看同事们编码实践,但是自己却只是概念 ...
- Natapp内网穿透服务工具
在做微信开发的时候,调用微信接口成功之后,微信会回调我们事先配置好的一个接口.由于微信的服务是在外网的,所以这个回调接口也只能是外网,而且微信要求回调接口只能是通过ICP备案的域名,不能使用IP,所以 ...
- kali 系列学习05 - Nessus 安装及配置
Nessus 安装 1.https://www.tenable.com/products/nessus/select-your-operating-system 点此下载nessus选择适合自己 ...
- Guitar Pro 7教程之如何导入吉他谱
在前面的章节小编为大家也讲解了不少关于Guitar Pro 的相关教程,譬如{cms_selflink page='index' text='Guitar Pro下载'},安装等等一系列的使用教程,前 ...