【LeetCode-面试算法经典-Java实现】【008-String to Integer (atoi) (字符串转成整数)】
2023-09-14 09:06:22 时间
【008-String to Integer (atoi) (字符串转成整数)】
【LeetCode-面试算法经典-Java实现】【全部题目文件夹索引】
原题
Implement atoi to convert a string to an integer.
Hint: Carefully consider all possible input cases. If you want a challenge, please do not see below and ask yourself what are the possible input cases.
Notes: It is intended for this problem to be specified vaguely (ie, no given input specs). You are responsible to gather all the input requirements up front.
题目大意
实现一个atoi函数,将字符串转成整形
要点:考虑全部的输入情况。
解题思路
前导字符是+或-或者没有。接下来输入的是数字,数字不能整数能表示的最大或最小数。假设超过就返回相应的最小或者最小的值。
代码实现
public class Solution {
public int atoi(String str) {
if (str == null || str.length() == 0) {
// throw new NumberFormatException("Invalid input string: " + str);
return 0;
}
// 假设字符串以空格開始
int start = 0; //从開始找第一个不是空格的数
boolean positive = true; // 是否为正数默觉得true
if (str.charAt(start) == ' ') {
while (str.charAt(start) == ' ') {
start++;
if (start >= str.length()) { // 输入的全是空格
// throw new NumberFormatException("Invalid input string: " + str);
return 0;
}
}
}
if (str.charAt(start) == '-') { // 第一个非空白字符中-
positive = false;
start++;
} else if (str.charAt(start) == '+') {// 第一个非空白字符是+
start++;
} else if (str.charAt(start) >= '0' && str.charAt(start) <= '9') { // 第一个非空白字符是数字
return cal(str, start, true);
} else { // 其他情况就抛出异常
// throw new NumberFormatException("Invalid input string: " + str);
return 0;
}
if (start >= str.length()) { // 第一个非空白字符是+或者-但也是最后一个字符
// throw new NumberFormatException("Invalid input string: " + str);
return 0;
}
if (str.charAt(start) > '9' || str.charAt(start) < '0') { // +或者-后面接的不是数字
// throw new NumberFormatException("Invalid input string: " + str);
return 0;
} else {
return cal(str, start, positive);
}
}
private int cal(String str, int start, boolean positive) {
long result = 0;
while (start < str.length() && str.charAt(start) >= '0' && str.charAt(start) <= '9') {
result = result * 10 + (str.charAt(start) - '0');
if (positive) { // 假设是正数
if (result > Integer.MAX_VALUE) {
// throw new NumberFormatException("Invalid input string: " + str);
return Integer.MAX_VALUE;
}
} else {
if (-result < Integer.MIN_VALUE) {
// throw new NumberFormatException("Invalid input string: " + str);
return Integer.MIN_VALUE;
}
}
start++;
}
if (positive) {
return (int) result;
} else {
return (int) -result;
}
}
}
评測结果
点击图片,鼠标不释放。拖动一段位置,释放后在新的窗体中查看完整图片。
特别说明
欢迎转载,转载请注明出处【http://blog.csdn.net/derrantcm/article/details/46938417】
相关文章
- java字符串常用操作(查找、截取、分割)
- think in java一_Think in Java(一):Java基础「建议收藏」
- java pfx 证书_Java将pfx证书转换为jks[通俗易懂]
- java常量有哪些_JAVA常量介绍「建议收藏」
- 对java面向对象的三大特征的理解_Java面向对象的三大特征是什么?
- java中random方法取值范围_Java Random.nextInt()方法,随机产生某个范围内的整数
- Java算法大全_java贪心算法几个经典例子
- JAVA实验室设备管理系统代码_java做一个简单学生管理系统
- 【云驻共创】 JAVA常用的开发工具有哪些?
- Java开发之文件上传详解编程语言
- Java操作Oracle数据库:实现数据库连接与访问(java连接oracle数据库)
- Java中的字节流和字符流区别详解编程语言
- Java调试Linux:探索新的技术可能性(java调试Linux)
- 学习Linux,开启Java之旅(linuxjavaws)
- 时间Java设置Redis Key的过期时间(redisjava过期)
- 处理解决Redis中Java端操作过期存储的方法(redisjava过期)
- 使用Redis存储Java对象(redis存java对象)