对于strcat,其格式为
char *strcat(char *a, char *b);
其功能为,将字符串b拼接到a的尾部,并将结果字符串返回。
所以,实现该函数的思路为:
1 找到字符串a的结尾;
2 将b的所有字符复制到a尾部的空间中,到\0为止。
需要注意的是,复制的结果要包含b的结束符。
代码如下:
char *strcat(char *a, char *b)
{
char *p = a;
while(*p) p ++;
//当*p为\0时退出,即查找到a的结尾。
do
{
*p++ = *b;//将b中的每个字符复制到p中。
if(*b == '\0')break;//遇到结束符退出。
b++;//移动指针b的位置。
}while(1);
return a;//返回结果字符串首地址。
}
while(*a!='\0'){ //其实你每次都是判断a[0]!='0’这当然是个无限循环啦
c[i]=a[i];
i++;
}
你这代码我觉得用的数组知识更多,看我写的字符串拼接函数,希望对你有帮组#include
{
while(*(s++));
s--;
while(*ct)
*(s++) = *(ct++);
*s = '\0';
}int main()
{
char na[100],nb[100];
gets(na);
gets(nb);
mystrcat(na,nb);
printf("%s\n",na);
return 0;
}
你的循环控制条件写错了 应改为*(a+i)!='\0'和*(b+j)!='\0'#include
void pinjie(char *a,char *b)
{
int i=0,j=0;
char c[200];
while(*(a+i)!='\0')
{
c[i]=a[i];
i++;
}
while(*(b+j)!='\0')
{
c[i]=b[j];
i++,j++;
}
c[i]='\0';
puts(c);
}int main()
{
char na[100],nb[100];
gets(na),gets(nb);
pinjie(na,nb);
}