剑指offer——把字符串转换成整数
1 知识点储备
1.1 字符串与整数相互转换常用库函数
1)String转换成int类型:在 Java 中要将 String 类型转化为 int 类型时,需要使用 Integer 类中的 parseInt()
方法或者 valueOf()
方法进行转换。
int i = Integer.parseInt([String]);//直接使用静态方法,不会产生多余的对象,但会抛出异常
int i = Integer.valueOf(my_str).intValue();//Integer.valueOf(s) 相当于 new Integer(Integer.parseInt(my_str)),也会抛异常,但会多产生一个对象
举例:
利用parseInt()
方法:
String str="123";
try{
int a = Integer.parseInt(str);
} catch (NumberFormatException e){
e.printStackTrace();
}
利用valueOf()
方法:
String str="123";
try{
int b = Integer.valueOf(str).intValue();
}catch(NumberFormatException e){
e.printStackTrace();
}
2)int类型转换成String类:在 Java 中要将 int 类型转化为 String 类型时,需要使用 Integer 类中的 toString()
方法或者String类中的 valueOf()
方法进行转换,也可以使用重载的 “+” 运算符进行强制类型转换,即: + ""
。
- 通过
Integer.toString(i)
方法转换:利用String s = Integer.toString(i);
- 通过
String.valueOf(i)
方法转换为字符串:利用String s = String.valueOf(i);//直接使用String类的静态方法,只产生一个对象
- 通过‘+’链接,将整型强制转换一下字符串:利用
String s = "" + i;//会产生两个String对象
1.2 必背ASCII码
ASCII码从0到127,即(2的0次方减1)到(2的7次方减1).
- 字符’0’对应的ASCII码值是48(转化为int类型);
- 字符’9’对应的ASCII码值是57 (48+10-1=57);
- 字符‘A’对应的ASCII码值是65;
- 字符‘Z’对应的ASCII码值是90(65+26-1=90);
- 字符‘a’对应的ASCII码值是97;
- 字符‘z’对应的ASCII码值是122(97+26-1=122);
- 字符‘NULL(null)’对应的ASCII码值是0,‘NULL(null)’解释为空字符;
- 字符‘ (space)’对应的ASCII码值是40,‘ (space)’解释为空格;
其他相关ASCII码值见百度百科:ASCII
2 题目描述
将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0
2.1 输入描述:
输入一个字符串,包括数字字母符号,可以为空
2.2 输出描述:
如果是合法的数值表达则返回该数字,否则返回0
2.3 示例1
输入
+2147483647
1a33
输出
2147483647
0
2.4 题目分析
边界条件:
- 空字符串,字符串长度为0;
- 数据上下 溢出;
- 只有正负号;
- 有无正负号;
- 错误标志输出。
2.5 答案
public class Solution {
public int StrToInt(String str) {
if(str=="" || str.length()==0){
return 0;
}
int sum=0;
int fuhao=1;//当第一位为正或无符号时,置符号位为1
if(str.charAt(0)== '-'){
str=str.substring(1,str.length());
char[] a = str.toCharArray();
fuhao=-1;
}else if(str.charAt(0)=='+'){
str=str.substring(1,str.length());
char[] a = str.toCharArray();
}else{
char[] a = str.toCharArray();
}
for(int i=0; i<a.length; i++){
if(a[i]<48 || a[i]>57){
return 0;
}//一定注意排除不合法的数值表达式
sum=sum*10+a[i]-48;//计算该整数值
}
sum=sum*fuhao;
return sum;
}
}
编译错误:
不通过
您的代码已保存
编译错误:您提交的代码无法完成编译
./Solution.java:20: error: cannot find symbol
for(int i=0; i ^
symbol: variable a
location: class Solution
./Solution.java:21: error: cannot find symbol
if(a[i]<48 || a[i]>57){
^
symbol: variable a
location: class Solution
./Solution.java:21: error: cannot find symbol
if(a[i]<48 || a[i]>57){
^
symbol: variable a
location: class Solution
./Solution.java:24: error: cannot find symbol
sum=sum*10+a[i]-48;//??????
^
symbol: variable a
location: class Solution
4 errors
理由:字符串数组a在if语句里定义,出了if语句之后,数组失去意义。
改正后的代码:
public class Solution {
public int StrToInt(String str) {
if(str=="" || str.length()==0){
return 0;
}
int sum=0;
int fuhao=1;//当第一位为正或无符号时,置符号位为1
if(str.charAt(0)== '-'){
str=str.substring(1,str.length());
//char[] a = str.toCharArray();
fuhao=-1;
}else if(str.charAt(0)=='+'){
str=str.substring(1,str.length());
//char[] a = str.toCharArray();
}
char[] a = str.toCharArray();
for(int i=0; i<a.length; i++){
if(a[i]<48 || a[i]>57){
return 0;
}//一定注意排除不合法的数值表达式
sum=sum*10+a[i]-48;//计算该整数值
}
sum=sum*fuhao;
return sum;
}
}