剑指offer——把字符串转换成整数(Java中int与String的相互转换、ASCII码)

剑指offer——把字符串转换成整数

1 知识点储备

1.1 字符串与整数相互转换常用库函数

1)String转换成int类型:在 Java 中要将 String 类型转化为 int 类型时,需要使用 Integer 类中的 parseInt() 方法或者 valueOf() 方法进行转换。

  1. int i = Integer.parseInt([String]);//直接使用静态方法,不会产生多余的对象,但会抛出异常
  2. 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() 方法进行转换,也可以使用重载的 “+” 运算符进行强制类型转换,即: + ""

  1. 通过Integer.toString(i)方法转换:利用 String s = Integer.toString(i);
  2. 通过String.valueOf(i)方法转换为字符串:利用String s = String.valueOf(i);//直接使用String类的静态方法,只产生一个对象
  3. 通过‘+’链接,将整型强制转换一下字符串:利用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 题目分析

边界条件:

  1. 空字符串,字符串长度为0;
  2. 数据上下 溢出;
  3. 只有正负号;
  4. 有无正负号;
  5. 错误标志输出。

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; iif(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; iif(a[i]<48 || a[i]>57){
                return 0;
            }//一定注意排除不合法的数值表达式
            sum=sum*10+a[i]-48;//计算该整数值
        }
        sum=sum*fuhao;
        return sum;
    }
}

你可能感兴趣的:(剑指offer)