itoa

功 能: 把一整数转换为字符串

  用 法: char *itoa(int value, char *string, int radix);

  头文件: <stdlib.h>

  程序例:

  #include <stdlib.h>

  #include <stdio.h>

  int main()

  {

  int number = 123456;

  char string[25];

  itoa(number, string, 10);

  printf("integer = %d string = %s/n", number, string);

  return 0;

  }

  /* 实现itoa函数的源代码 */

  char *myitoa(int num,char *str,int radix)

  {

  /* 索引表 */

  char index[]="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";

  unsigned unum; /* 中间变量 */

  int i=0,j,k;

  /* 确定unum的值 */

  if(radix==10&&num<0) /* 十进制负数 */

  {

  unum=(unsigned)-num;

  str[i++]='-';

  }

  else unum=(unsigned)num; /* 其他情况 */

  /* 逆序 */

  do

  {

  str[i++]=index[unum%(unsigned)radix];

  unum/=radix;

  }while(unum);

  str[i]='/0';

  /* 转换 */

  if(str[0]=='-') k=1; /* 十进制负数 */

  else k=0;

  /* 将原来的“/2”改为“/2.0”,保证当num在16~255之间,radix等于16时,也能得到正确结果 */

  for(j=k;j<(i-1)/2.0+k;j++)

  {

  num=str[j];

  str[j]=str[i-j-1+k];

  str[i-j-1+k]=num;

  }

  return str;

  }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值