本题要求实现一个函数,将两个字符串连接起来。
函数接口定义:
char *str_cat( char *s, char *t );
函数
str_cat
应将字符串t
复制到字符串s
的末端,并且返回字符串s
的首地址。
裁判测试程序样例:
#include <stdio.h>
#include <string.h>
#define MAXS 10
char *str_cat( char *s, char *t );
int main()
{
char *p;
char str1[MAXS+MAXS] = {'\0'}, str2[MAXS] = {'\0'};
scanf("%s%s", str1, str2);
p = str_cat(str1, str2);
printf("%s\n%s\n", p, str1);
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
abc
def
输出样例:
abcdef
abcdef
问题分析:
数出字符串s的末端,然后从这一位置开始进行字符串的复制即可。
代码实现
char *str_cat( char *s, char *t ){
int i=0;
while(s[i]!='\0'){
i++;
}
for(int j=0;t[j]!='\0';j++,i++){
s[i]=t[j];
}
s[i]='\0';
return s;
}
提交结果