本文共 1430 字,大约阅读时间需要 4 分钟。
面试中被问到了这个问题,当时答得不太好,没有考虑全面,回来总结一下,如有遗漏,欢迎指正。
知道C语言中有2个函数atoi()和 itoa(),但对具体实现不是很清楚,现在自己总结实现一下:
/*把字符串转换成整型数 atoi()*/int str2int(char s[]) { int temp=0; int flag=1; int i=0; while(i更新于2017.9.13='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");}
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; }}
转载地址:http://zqbti.baihongyu.com/