itoa的源代碼實現

 linux上沒有找到這個函數  在此做個記錄

#include <stdlib.h> 
#include <stdio.h> 
char *myitoa(int num,char *str,int radix);
int main() 
{ 
	int number = -123456; 
	char string[25]; 
	myitoa(number, string, 16); 
	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時,也能得到正確結果 */ 
	char temp; 
	for(j=k;j<=(i-k-1)/2.0;j++) 
	{ 
		temp=str[j]; 
		str[j]=str[i-j-1]; 
		str[i-j-1]=temp; 
	} 
	return str; 
} 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章