整数反转

题目地址:https://leetcode-cn.com/problems/reverse-integer/

给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。

示例 1:

输入: 123
输出: 321

示例 2:

输入: -123
输出: -321

示例 3:

输入: 120
输出: 21

注意:

假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为 [−2^31, 2^31 − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。

解法一:暴力解法

主体

  1. 整数转字符串

  2. 字符串的反转

  3. 字符串转整数

边界

  • 数值溢出边界:溢出返回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 整数反转的更多相关文章

  1. LeetCode初级算法之字符串:344 反转字符串

    反转字符串 题目地址:https://leetcode-cn.com/problems/reverse-string/ 编写一个函数,其作用是将输入的字符串反转过来.输入字符串以字符数组 char[] ...

  2. 算法练习LeetCode初级算法之字符串

    反转字符串 我的解法比较low,利用集合的工具类Collections.reverse反转,用时过长 class Solution { public void reverseString(char[] ...

  3. LeetCode初级算法之字符串:387 字符串中的第一个唯一字符

    字符串中的第一个唯一字符 题目地址:https://leetcode-cn.com/problems/first-unique-character-in-a-string/ 给定一个字符串,找到它的第 ...

  4. LeetCode初级算法之字符串:242 有效的字母异位词

    有效的字母异位词 题目地址:https://leetcode-cn.com/problems/valid-anagram/ 给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位 ...

  5. 【LeetCode算法】LeetCode初级算法——字符串

      在LeetCode初级算法的字符串专题中,共给出了九道题目,分别为:反转字符串,整数反转,字符串中的第一个唯一字符,有效的字母异位词,验证回文字符串,字符串转换整数,实现strStr(),报数,最 ...

  6. LeetCode初级算法--字符串01:反转字符串

    LeetCode初级算法--字符串01:反转字符串 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.ne ...

  7. LeetCode初级算法的Python实现--字符串

    LeetCode初级算法的Python实现--字符串 # 反转字符串 def reverseString(s): return s[::-1] # 颠倒数字 def reverse(x): if x ...

  8. LeetCode初级算法--链表01:反转链表

    LeetCode初级算法--链表01:反转链表 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.net/ ...

  9. LeetCode初级算法--字符串02:字符串中的第一个唯一字符

    LeetCode初级算法--字符串02:字符串中的第一个唯一字符 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog. ...

随机推荐

  1. Spider_知识目录_基础

    知识目录 静态网页抓取 Spider_基础总结1_Request(get/post__url传参_headers_timeout)+Reponse Spider_基础总结2_Requests异常 Sp ...

  2. tcp timewait 问题 转载

    TIME WAIT 带来的问题 先引用一个名言: The TIME_WAIT state is our friend and is there to help us (i.e., to let old ...

  3. TypeScript 引入第三方包,报无法找到模块错误

    以 react-router-dom 模块为例 1. npm加上 @types/ 根据报错提示尝试安装该库的TypeScript版本 (该库的 ts 声明文件),也就是在该库的名称前加上 @types ...

  4. mac 快键键图标对应

    Mac 键盘快捷键 您可以按下某些组合键来实现通常需要鼠标.触控板或其他输入设备才能完成的操作.   要使用键盘快捷键,请按住一个或多个修饰键,然后按快捷键的最后一个键.例如,要使用 Command- ...

  5. 解决docker镜像无vim

    docker拉取的镜像一般都是ubantu系统 安装vim apt-get update apt-get vim

  6. [原题复现+审计][RoarCTF 2019]Easy Calc(http协议走私、php字符串解析漏洞)

    简介  原题复现:  考察知识点:http协议走私.php字符串解析漏洞  线上平台:https://buuoj.cn(北京联合大学公开的CTF平台) 榆林学院内可使用信安协会内部的CTF训练平台找到 ...

  7. hive显示列名

    查询时显示列名:hive> set hive.cli.print.header;hive.cli.print.header=falsehive> set hive.cli.print.he ...

  8. IDEA创建WebService服务端与客户端

    创建服务端 一.file–>new–>project 二.点击next后输入服务端名,点击finish,生成目录如下 三.在 HelloWorld.Java 文件中右击,选 Tools 的 ...

  9. CorelDRAW多个文件如何批量导出JPG

    好多同学对于CorelDRAW 2018批量导出图片格式的操作不太了解.这种情况比较常见,比如设计了一本画册,在同一个文档中页面比较多,如果一页一页导出那将是一项巨大的工程,这时候我们就会想到CDR的 ...

  10. Java中的主线程

    目录 概览 主线程 怎么来控制主线程 主线程和main()函数的关系 主线程中的死锁(单个线程) 概览 前段时间有同事提到了主线程这个名词,但当时我们说的主线程是指Java Web程序中每一个请求进来 ...