重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

atoi函数c语言,c语言atoi函数源代码

c语言atoi函数源代码

c语言atoi函数源代码:

成都创新互联公司是一家专注于网站设计、网站制作与策划设计,云安网站建设哪家好?成都创新互联公司做网站,专注于网站建设10年,网设计领域的专业建站公司;建站业务涵盖:云安等地区。云安做网站价格咨询:18980820575

int atoi(char n[])

{int i,y=0;

for(i=0;n[i]='0' n[i]='9';i++)

y=y*10+n[i]-'0';

return y;

}

c语言atoi函数求助

abcd转换数值? 你是要做16进制的吗?

一般atoi只是转换10进制的 不包括16进制

如果你要支持16进制 可以自行增加一个前导符 比较常用的是x

即如果字符串第一个字符为x 则表示改字符串为16进制形式

判断和你现有的符号判断类似,处理数据的时候不能用isdigit判断 而是要加入a-f的判断

计算的时候 10*n改成16*n

简单的例子

int atoi(char s[])

{

int i, n, sign;

for (i = 0; isspace(s[i]); i++)  /* skip white space */

;

if(s[i] == 'x')/*hex*/

{

i ++;

for (n = 0; isdigit(s[i]) || (s[i]='a'  s[i] = 'f'); i++)

{

if(isdigit(s[i]))

n = 16 * n + (s[i] - '0');

else

n = 16 * n + (s[i] - 'a')+10; 

}

return n;

}

sign = (s[i] == '-') ? -1 : 1;

if (s[i] == '+' || s[i] == '-')  /* skip sign */

i++;

for (n = 0; isdigit(s[i]); i++)

n = 10 * n + (s[i] - '0');

return sign * n;

}

c语言atoi用法介绍?

函数名: atoi

功 能: 把字符串转换成长整型数

用 法: #include stdlib.h

int atoi(const char *nptr);

程序例:

#include stdlib.h

#include stdio.h

int main(void)

{

int n;

char *str = "1234";

n = atoi(str);

printf("string = %s integer = %d\n", str, n);

return 0;

}

运行结果是:

string =1234 integer=1234

c语言atoi函数

跟一行两行没关系, 跟了参数,就会大于1了,第一个参数是程序本身,第二个参数开始才是真正的参数

如何用C语言实现atoi()函数

要善用百度。。。百度百科就有atoi这个词条,里面有c语言实现的源代码(其实是c++,不过唯一的不同只是它的字符串定义为了const,即常量,表示在函数里不允许改变此字符串内容)

我在这里加上注释简单说明一下该源码

int

my_atoi(const

char

*str){

int

result;

//保存返回结果的

int

signal

=

1;

//保存符号的,默认正数

//判断第一个数字是否合法

if((*str='0'*str='9')||*str=='-'||*str=='+'){

//如果是-,符号变为-1,指针右移

//如果是+,指针右移(总之指向了第一个数字)

if(*str=='-'||*str=='+'){

if(*str=='-')

signal

=

-1;

str++;

}

}

else

return

0;//第一个不是+,-或数字,非法返回0

//这里就是转换,是数学的问题就不解释了

while(*str='0'*str='9')

result

=

result*10+(*str++

-'0');

return

signal*result;

}

不过这个程序,如果字符串是非法的话,他也会返回直到非法字符之前的数值

比如123abc

返回值就是123


文章题目:atoi函数c语言,c语言atoi函数源代码
转载注明:http://cqcxhl.com/article/hsppjd.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP