strcpy 版本:

char * strcpy( char *strDest, const char *strSrc )

{

assert( (strDest != NULL) && (strSrc != NULL) );

char *address = strDest;

while( (*strDest++ = * strSrc++) != \0’ );

return address;

}

&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&

 

strlen 函数:

int strlen( const char *str ) //输入参数const

{

assert( strt != NULL ); //断言字符串地址非0

int len;

while( (*str++) != '\0' )

 

{

len++;

}

return len;

}

&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&

 实现strcat函数  int   my_strcat(char *p1,char *p2);

 

 

int my_strcat(char *p1,char *p2)

  {     

        char *temp_p1=p1;

        char *temp_pm=p1;

        int count;

        count=strlen(p1);

       strcpy((temp_p1+count),p2);

      // printf("%s",temp_pm);

}

&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&

 

题目: 请编写一个 C 函数,该函数将给定的一个字符串转换成整数。
(面试时如果时间紧张,不能对过多的限制条件一一考虑,则注明本程序的限制条件,这能说明你考虑问题比较全面,即使你没有具体实现,相信面试官会认为你已经实现了)
 
下面的程序仅仅是考虑十进制字符串(不考虑非法字符的问题)。
int StrToInt(char * str)
{
   int value = 0;
   int sign = 1;
   if(*str == '-')
   {
      sign = -1;
      str++;
   }
   while(*str)
   {
      value = value * 10 + *str - '0';
       // 此法很巧妙,直接从高位开始乘加即可,不用考虑字符串的长度
      str++;
   }
   return sign*value;
}
当然也可以利用strlen或找结束字符的方式寻找最低位,乘数变化即可
 
下面的程序考虑了八进制、十进制、十六进制的字符串。
 
int StrToInt(char * str)
{
   int value = 0;
   int sign = 1;
   int radix;
 
   if(*str == '-')
   {
      sign = -1;
      str++;
   }
   if(*str == '0' && (*(str+1) == 'x' || *(str+1) == 'X'))
   {
      radix = 16;
      str += 2;
   }
   else if(*str == '0')      // 八进制首字符为0
   {
      radix = 8;
      str++;
   }
   else
      radix = 10;
   while(*str)
   {
      if(radix == 16)
      {
        if(*str >= '0' && *str <= '9')
           value = value * radix + *str - '0';
        else
           value = value * radix + (*str | 0x20) - 'a' + 10;
       // value = value * radix + *str - 'a' + 10; // 也没问题啊
      }
      else
        value = value * radix + *str - '0';
      str++;
   }
   return sign*value;
}
整数转换为字符串
void itoa (int n,char s[])
{
int i,j,sign;
if((sign=n)<0)//记录符号
        n=-n;//使n成为正数         i=0;
do{
        s[i++]=n+’0’;//取下一个数字
}while ((n/=10)>0);//删除该数字
if(sign<0)
        s[i++]=’-’;
s[i]=’’;
for(j=i;j>=0;j--)//生成的数字是逆序的,所以要逆序输出
        printf("%c",s[j]);
}
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&