天天看點

C++字元串庫函數——strcat,strcmp,strlen,itoa

C++字元串庫函數——strcat,strcmp,strlen,itoa

#include<iostream>
#include<assert.h> 
using namespace std;
char *strcat(char * strDest,const char *strSrc)
{
	char *address=strDest;
	assert((strDest!=NULL)&&(strSrc!=NULL));
	while(*strDest)
		strDest++;
	while(*strDest++=*strSrc++)
	{
		NULL;
	}
	return address;
}

int strcmp (const char *str1,const char *str2)
{           
	int len = 0;
	assert((str1 != '\0') && (str2 != '\0'));
	while(*str1 && *str2 && (*str1 == *str2))
	{
		str1++;
		str2++;
	}
	return *str1-*str2;
}
int mystrlen(const char *str)
{
	int len = 0;
	assert(str != NULL);
	while(*str++)
	{
		len++;
	}
	return len;
}
char *itoa(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; 
} 

int main()
{
	char s1[50],s2[50];
	int n;
	while(cin>>s1>>s2)
	{
		cout<<strcat(s1,s2)<<endl;
		cout<<strcmp(s1,s2)<<endl;
		cout<<mystrlen(s1)<<' '<<mystrlen(s2)<<endl;
		cin>>n;
		cout<<itoa(n,s1,16)<<' '<<itoa(n,s2,8)<<endl;
	}
	return 0;
}

           

轉載于:https://www.cnblogs.com/tgkx1054/archive/2012/11/26/2789829.html