算法笔记_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
- 算法笔记_028-字符串转换成整数(Java)
- 算法笔记_028-字符串转换成整数(Java)
- 算法笔记_028-字符串转换成整数(Java)
- 算法笔记_028-字符串转换成整数(Java)
- 算法笔记_028-字符串转换成整数(Java)
- 数据结构与算法分析笔记与总结(java实现)--字符串3:把字符串转换成整数
- java经典算法_028打印出杨辉三角形
- 把字符串转换成整数[算法]
- 把字符串转换成整数(Java实现)
- 把字符串转换成整数(java版)
- [Java] 自己实现字符串转换成整数
- 字符串转换成整数java实现
- Java代码 将字符串转换成整数
- 将字符串转换成整数[Java]
- 把字符串转换成整数java实现
- 把字符串转换成整数 java实现
- 把字符串转换成整数(字符串)
- 算法:将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。
- 由于ls可在‘/bin’处找到,由于/bin不在PATH环境变量中,故无法找到该命令
- 项目成本管理 教材精选
- 封装图片上传插件(用到html5技术)
- nginx 源码阅读(2)
- 第六届蓝桥杯JavaA组第一题
- 算法笔记_028-字符串转换成整数(Java)
- 单片机DS18b20 温度检测液晶显示
- 使用IDA调试Android原生程序中遇到的问题及解决方法
- Could not calculate build plan: Plugin org.apache.maven.plugins:maven-resources-plugin:2.6
- C++ Primer课后练习12.2
- Dropout资源【2】
- MATLAB常用函数
- win10的linux子系统的安装、卸载与使用
- Java排序算法(转)