头文件:#include <stdlib.h>



atoi() 函数用来将字符串转换成整数(int),其原型为:

int atoi (const char * str);



【函数说明】atoi() 函数会扫描参数 str 字符串,跳过前面的空白字符(例如空格,tab缩进等,可以通过 isspace() 函数来检测),直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('\0')才结束转换,并将结果返回。



【返回值】返回转换后的整型数;如果 str 不能转换成 int 或者 str 为空字符串,那么将返回 0。



温馨提示:ANSI C 规范定义了 stof()atoi()atol()strtod()strtol()strtoul() 共6个可以将字符串转换为数字的函数,大家可以对比学习。另外在
C99 / C++11 规范中又新增了5个函数,分别是 atoll()、strtof()、strtold()、strtoll()、strtoull(),在此不做介绍,请大家自行学习。



范例:将字符串a 与字符串b 转换成数字后相加。

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. int main ()
  4. {
  5. int i;
  6. char buffer[256];
  7. printf ("Enter a number: ");
  8. fgets (buffer, 256, stdin);
  9. i = atoi (buffer);
  10. printf ("The value entered is %d.", i);
  11. system("pause");
  12. return 0;
  13. }

执行结果:

Enter a number: 233cyuyan

The value entered is 233.

转自:http://c.biancheng.net/cpp/html/125.html

-------------------------------------------------------------------

C语言提供了几个标准库函数,可以将任意类型(整型、长整型、浮点型等)的数字转换为字符串。

1.int/float to string/array:

C语言提供了几个标准库函数,可以将任意类型(整型、长整型、浮点型等)的数字转换为字符串,下面列举了各函数的方法及其说明。

● itoa():将整型值转换为字符串。

● ltoa():将长整型值转换为字符串。

● ultoa():将无符号长整型值转换为字符串。

● gcvt():将浮点型数转换为字符串,取四舍五入。

● ecvt():将双精度浮点型值转换为字符串,转换结果中不包含十进制小数点。

● fcvt():指定位数为转换精度,其余同ecvt()。



除此外,还可以使用sprintf系列函数把数字转换成字符串,其比itoa()系列函数运行速度慢



2. string/array to int/float

C/C++语言提供了几个标准库函数,可以将字符串转换为任意类型(整型、长整型、浮点型等)。

● atof():将字符串转换为双精度浮点型值。

● atoi():将字符串转换为整型值。

● atol():将字符串转换为长整型值。

● strtod():将字符串转换为双精度浮点型值,并报告不能被转换的所有剩余数字。

● strtol():将字符串转换为长整值,并报告不能被转换的所有剩余数字。

● strtoul():将字符串转换为无符号长整型值,并报告不能被转换的所有剩余数字。



以下是用itoa()函数将整数转换为字符串的一个例子:

# include <stdio.h>

# include <stdlib.h>

void main (void)

{

int num = 100;

char str[25];

itoa(num, str, 10);

printf("The number 'num' is %d and the string 'str' is %s. \n" ,

num, str);

}



itoa()函数有3个参数:第一个参数是要转换的数字,第二个参数是要写入转换结果的目标字符串,第三个参数是转移数字时所用 的基数。在上例中,转换基数为10。10:十进制;2:二进制...



itoa并不是一个标准的C函数,它是Windows特有的,如果要写跨平台的程序,请用sprintf。是Windows平台下扩展的,标准库中有sprintf,功能比这个更强,用法跟printf类似:



char str[255];

sprintf(str, "%x", 100); //将100转为16进制表示的字符串。



下列函数可以将整数转换为字符串:

----------------------------------------------------------

函数名 用

----------------------------------------------------------

itoa() 将整型值转换为字符串

itoa() 将长整型值转换为字符串

ultoa() 将无符号长整型值转换为字符串



一、atoi()——把字符串转换成整型数

考点:字符串转换为数字时,对相关ASCII码的理解。
 

C实现:

#include <ctype.h>

#include <stdio.h>

int atoi (char s[]);

int main(void )

{

char s[100];

gets(s);

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

return 0;

}

int atoi (char s[])

{

int i,n,sign;

for(i=0;isspace(s[i]);i++)//跳过空白符;

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

if(s[i]=='+'||s[i]==' -')//跳过符号

  i++;

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

       n=10*n+(s[i]-'0');//将数字字符转换成整形数字

return sign *n;

}





C++实现:

1    #include <iostream>

2    using namespace std;

3  

4    int str2int(const char *str)

5    {

6        int temp = 0;

7        const char *ptr = str;  //ptr保存str字符串开头

8  

9        if (*str == '-' || *str == '+')  //如果第一个字符是正负号,

10       {                      //则移到下一个字符

11           str++;

12       }

13       while(*str != 0)

14       {

15           if ((*str < '0') || (*str > '9'))  //如果当前字符不是数字

16           {                       //则退出循环

17               break;

18           }

19           temp = temp * 10 + (*str - '0'); //如果当前字符是数字则计算数值

20           str++;      //移到下一个字符

21       }  

22       if (*ptr == '-')     //如果字符串是以“-”开头,则转换成其相反数

23       {

24           temp = -temp;

25       }

26 

27       return temp;

28   }

29 

30   int main()

31   {

32       int n = 0;  

33       char p[10] = "";

34 

35       cin.getline(p, 20);   //从终端获取一个字符串

36       n = str2int(p);      //把字符串转换成整型数

37      

38       cout << n << endl;

39 

40       return 0;

41   }



二、itoa()——把一整数转换为字符串

通过把整数的各位上的数字加“0”转换成char类型并存到字符数组中。但是要注意,需要采用字符串逆序的方法
 
C语言实现:

#include <ctype.h>

#include <stdio.h>

void      itoa (int n,char s[]);

//atoi 函数:将s转换为整形数

int main(void )

{

int n;

char s[100];

printf("Input n:\n");

scanf("%d",&n);

printf("the string : \n");

itoa (n,s);

return 0;

}

void itoa (int n,char s[])

{

int i,j,sign;

if((sign=n)<0)//记录符号

n=-n;//使n成为正数

i=0;

do{

       s[i++]=n%10+'0';//取下一个数字

}

while ((n/=10)>0);//删除该数字

if(sign<0)

s[i++]='-';

s[i]='\0';

for(j=i;j>=0;j--)//生成的数字是逆序的,所以要逆序输出

       printf("%c",s[j]);

}



是int 转string类型的一个函数
 
C++实现:
1    #include <iostream>

2    using namespace std;

3   

4    void int2str(int n, char *str)

5    {

6        char buf[10] = "";

7        int i = 0;

8        int len = 0;

9        int temp = n < 0 ? -n: n;  // temp为n的绝对值

10  

11       if (str == NULL)

12       {

13           return;

14       }

15       while(temp)

16       {

17           buf[i++] = (temp % 10) + '0';  //把temp的每一位上的数存入buf

18           temp = temp / 10;

19       }

20  

21       len = n < 0 ? ++i: i;  //如果n是负数,则多需要一位来存储负号

22       str[i] = 0;            //末尾是结束符0

23       while(1)

24       {

25           i--;

26           if (buf[len-i-1] ==0)

27           {

28               break;

29           }

30           str[i] = buf[len-i-1];  //把buf数组里的字符拷到字符串

31       }

32       if (i == 0 )

33       {

34           str[i] = '-';          //如果是负数,添加一个负号

35       }

36   }

37  

38   int main()

39   {

40       int nNum;

41       char p[10];

42  

43       cout << "Please input an integer:";

44       cin >> nNum;

45       cout << "output: " ;

46       int2str(nNum, p);        //整型转换成字符串

47       cout<< p << endl;

48  

49       return 0;

50   }

转自:http://www.cnblogs.com/bluestorm/p/3168719.html

[置顶] C语言itoa()函数和atoi()函数详解(整数转字符C实现)的更多相关文章

  1. 【转载】C语言itoa()函数和atoi()函数详解(整数转字符C实现)

    本文转自: C语言itoa()函数和atoi()函数详解(整数转字符C实现) 介绍 C语言提供了几个标准库函数,可以将任意类型(整型.长整型.浮点型等)的数字转换为字符串. int/float to ...

  2. C语言itoa()函数和atoi()函数详解(整数转字符C实现)

    1.int/float to string/array: C语言提供了几个标准库函数,可以将任意类型(整型.长整型.浮点型等)的数字转换为字符串,下面列举了各函数的方法及其说明. ● itoa():将 ...

  3. C语言itoa()函数和atoi()函数详解(整数转字符)

    http://c.biancheng.net/cpp/html/792.html C语言提供了几个标准库函数,可以将任意类型(整型.长整型.浮点型等)的数字转换为字符串. 以下是用itoa()函数将整 ...

  4. C语言itoa()函数和atoi()函数详解(整数转字符C实现)【转载】

    文章转载自https://www.cnblogs.com/bluestorm/p/3168719.html   C语言提供了几个标准库函数,可以将任意类型(整型.长整型.浮点型等)的数字转换为字符串. ...

  5. (转)[置顶] Android APK反编译就这么简单 详解(附图) .

    在学习Android开发的过程你,你往往会去借鉴别人的应用是怎么开发的,那些漂亮的动画和精致的布局可能会让你爱不释手,作为一个开发者,你可能会很想知道这些效果界面是怎么去实现的,这时,你便可以对改应用 ...

  6. [置顶] Java WebService接口生成和调用 图文详解

    webservice简介: Web Service技术, 能使得运行在不同机器上的不同应用无须借助附加的.专门的第三方软件或硬件, 就可相互交换数据或集成.依据Web Service规范实施的应用之间 ...

  7. [置顶] Objective-C ,ios,iphone开发基础:UIAlertView使用详解

    UIAlertView使用详解 Ios中为我们提供了一个用来弹出提示框的类 UIAlertView,他类似于javascript中的alert 和c#中的MessageBox(); UIAlertVi ...

  8. [置顶] xamarin android toolbar(踩坑完全入门详解)

    网上关于toolbar的教程有很多,很多新手,在使用toolbar的时候踩坑实在太多了,不好好总结一下,实在浪费.如果你想学习toolbar,你肯定会去去搜索androd toolbar,既然你能看到 ...

  9. Go语言的GOPATH与工作目录详解

    这篇文章主要介绍了Go语言的GOPATH与工作目录详解,本文详细讲解了GOPATH设置.应用目录结构.编译应用等内容,需要的朋友可以参考下 GOPATH设置 go 命令依赖一个重要的环境变量:$GOP ...

随机推荐

  1. H3C光模块相关命令和检测方法

    <Sysname>  dis transceiver interface GigabitEthernet 1/0/28  查看 GigabitEthernet1/0/28 transcei ...

  2. Linux 内核是如何构建

    https://github.com/MintCN/linux-insides-zh 介绍 我不会告诉你怎么在自己的电脑上去构建.安装一个定制化的 Linux 内核,这样的资料太多了,它们会对你有帮助 ...

  3. CodeWars上的JavaScript技巧积累

    https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/slice The sli ...

  4. 文件系统中跳转【TLCL】

    pwd - Print name of current working directory cd - Change directory ls - List directory contents Lin ...

  5. linux基础(10)-导航菜单

    导航菜单实战 例:编写一个shell脚本,包含多个菜单,其中需要一个退出选项:可单选也可多选:根据序号选择后,显示所选菜单名称. #!/bin/bash ####################### ...

  6. 广西邀请赛 B+K

    B是一个看起来很KDT的题  但是因为KDT是n^1.5的所以t  而且因为KDT需要周期性的重建所以复杂度会更高 因为只有51种颜色 所以想当然的就去想了状态压缩 因为询问的区间范围 x一定是从1开 ...

  7. POJ2741 Colored Cubes

    Description There are several colored cubes. All of them are of the same size but they may be colore ...

  8. 使用java代码打开特定网页

    第一种方法的代码如下所示: import java.io.File; public class Test04 { public static void main(String[] args) { // ...

  9. EF-按字段读取

    /// <summary> /// 直接获取特定一个或者多个字段的值 /// 多个字段需要声明Model /// var s= testDal.GetScalar<dynamic&g ...

  10. poj2396有源汇上下界可行流

    题意:给一些约束条件,要求算能否有可行流,ps:刚开始输入的是每一列和,那么就建一条上下界相同的边,这样满流的时候就一定能保证流量相同了,还有0是该列(行)对另一行每个点都要满足约束条件 解法:先按无 ...