Java实现字符串转换成整数

算法 同时被 2 个专栏收录
72 篇文章 26 订阅
50 篇文章 45 订阅

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


请输入一个由数字组成的字符串:
整数result = 2147483647


请输入一个由数字组成的字符串:
-10000000000
整数result = -2147483648
©️2022 CSDN 皮肤主题:编程工作室 设计师:CSDN官方博客 返回首页

打赏作者

南 墙

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值