博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
字符串转整型与整型转字符串
阅读量:4145 次
发布时间:2019-05-25

本文共 1430 字,大约阅读时间需要 4 分钟。

面试中被问到了这个问题,当时答得不太好,没有考虑全面,回来总结一下,如有遗漏,欢迎指正。

知道C语言中有2个函数atoi()和 itoa(),但对具体实现不是很清楚,现在自己总结实现一下:

字符串转整型

这个情况稍微复杂一些,要考虑全面
  1. 字符串开始有空格,要先判断过滤‘  123’
  2. 存在符号'+'和'-'要判断
  3. 存在小数点,也就是'123.45'转为整型是123
  4. 字符串超过整型int的范围,就转为int表示最边缘的数
  5. 存在不合法的字符串‘+-123’则转为-,‘123 456’’转为123,

整型转字符串

也要考虑全面,分析各种情况
首先要考虑正负号,然后倒序(a%10)的方式转成字符串,最后判断符号,倒序输出
/*把字符串转换成整型数  atoi()*/int str2int(char s[]) {	int temp=0;	int flag=1;	int i=0;	while(i
='0'&&s[i]<='9') { temp=temp*10+(s[i]-'0'); i++; if(temp<0) { //超出int范围-2147483648~2147483647 temp=2147483647; break; } } return flag*temp;}/*把整数转换为字符串 itoa()*/void int2str(int temp,char s[]) { int flag=1; if(temp<0) { temp=-temp; flag=-1; } int i=0; while(temp>0) { s[i]=temp%10+'0'; i++; temp=temp/10; } if(flag==-1) s[i++]='-'; s[i]='\0'; for(int j=i-1; j>=0; j--) printf("%c",s[j]); printf("\n");}
更新于2017.9.13
上述的方法s="-2147483648",超出整数最小范围的结果不对,做如下改进:
public class StrToInt {	public static void main(String[] args) {		// TODO Auto-generated method stub		String s=" -2147483648";		System.out.println(strToint(s));	}	 public static int strToint(String str) {		char []s=str.toCharArray();		int flag=1,sum=0;		if(s.length==0)			return 0;		int i=0;		while(i
'0'&&s[i]<'9') { sum=sum*10+(s[i]-'0'); if(sum<0 && flag==1){ return Integer.MAX_VALUE; } if(sum<0 && flag==-1){ return Integer.MIN_VALUE; } i++; } return flag*sum; }}
总结,遇到问题要先思考个1分钟,考虑清楚了再动手写,不能慌张!

转载地址:http://zqbti.baihongyu.com/

你可能感兴趣的文章
【C#】利用Conditional属性完成编译忽略
查看>>
VUe+webpack构建单页router应用(一)
查看>>
(python版)《剑指Offer》JZ01:二维数组中的查找
查看>>
Spring MVC中使用Thymeleaf模板引擎
查看>>
深入了解php底层机制
查看>>
PHP中的stdClass 【转】
查看>>
XHProf-php轻量级的性能分析工具
查看>>
OpenCV gpu模块样例注释:video_reader.cpp
查看>>
就在昨天,全球 42 亿 IPv4 地址宣告耗尽!
查看>>
Mysql复制表以及复制数据库
查看>>
Linux分区方案
查看>>
如何使用 systemd 中的定时器
查看>>
git命令速查表
查看>>
linux进程监控和自动重启的简单实现
查看>>
OpenFeign学习(三):OpenFeign配置生成代理对象
查看>>
OpenFeign学习(四):OpenFeign的方法同步请求执行
查看>>
OpenFeign学习(六):OpenFign进行表单提交参数或传输文件
查看>>
Ribbon 学习(二):Spring Cloud Ribbon 加载配置原理
查看>>
Ribbon 学习(三):RestTemplate 请求负载流程解析
查看>>
深入理解HashMap
查看>>