算法笔记_028-字符串转换成整数(Java)

来源:互联网 发布:ipad绿色上网软件 编辑:程序博客网 时间:2024/06/05 19:14

1 问题描述

输入一个由数字组成的字符串,请把它转换成整数并输出。例如,输入字符串123”,输出整数123

请写出一个函数实现该功能,不能使用库函数。

 

 


2 解决方案

解答本问题的基本思路:从左至右扫描字符串中的每个字符,把之前扫描得到的数字乘以10,再加上当前字符表示的数字。

但是,基本思路是这样,还要注意以下几点:

(1)最好判断一下输入是否为空。

(2)如果字符串的第一个字符是-’号,最终得到的整数必为负整数。

(3)输入的字符串中不能含有不是数字的字符。

(4)输入的字符串不能太长,否则转换成整数后会导致整数溢出。

具体实现代码如下:

package com.liuzhen.string_1;import java.util.Scanner;public class StringToInt {    public static int Max_INT = Integer.MAX_VALUE;    public static int Min_INT = Integer.MIN_VALUE;        public int getStringToInt(String A){        char[] arrayA = A.toCharArray();        int n = 0;        if(A.equals("") || A.equals(null))     //判断输入是否为空            return 0;        int i = 0;        while(arrayA[i] == ' ')   //处理字符串首位的空格            i++;        int sign = 1;   //用于判定输入字符串数字的正负,初始化为1表示为正数        if(arrayA[i] == '+' || arrayA[i] == '-'){            if(arrayA[i] == '-')                sign = -1;            i++;        }        while(i < arrayA.length && Character.isDigit(arrayA[i])){  //确定是数字0~9才执行循环            int c = arrayA[i] - '0';            //当输入字符串表示数为正数,且大于Max_INT            if(sign > 0 && (n > Max_INT/10 || (n == Max_INT/10 && c > Max_INT%10))){                n = Max_INT;                break;            }            //当输入字符串表示数为负数,且小于Min_INT            if(sign < 0 && (n + Min_INT/10 > 0 || (n + Min_INT/10 == 0 && c + Min_INT%10 > 0))){                n = Min_INT;                break;            }            //把之前得到的数字乘以10,再加上 当前字符表示的数字            n = n*10 + c;            i++;        }                return sign > 0 ? n : -n;    }    public static void main(String[] args){        StringToInt test = new StringToInt();        Scanner in = new Scanner(System.in);        System.out.println("请输入一个由数字组成的字符串:");        String A = in.nextLine();        int result = test.getStringToInt(A);        System.out.println("整数result = "+result);    }}

运行结果:

请输入一个由数字组成的字符串:  -1000整数result = -1000请输入一个由数字组成的字符串:+100000整数result = 100000请输入一个由数字组成的字符串:a1212整数result = 0请输入一个由数字组成的字符串:1000000000000整数result = 2147483647请输入一个由数字组成的字符串:-10000000000整数result = -2147483648

 

0 0
原创粉丝点击