PTA-字符串的连接

本题要求实现一个函数,将两个字符串连接起来。

函数接口定义:


char *str_cat( char *s, char *t );

函数str_cat应将字符串t复制到字符串s的末端,并且返回字符串s的首地址。

裁判测试程序样例:


#include  
#include  
#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

分析:

  1. 定义一个指针p,指向字符串s的末尾。
  2. 使用一个循环,遍历字符串s,找到其末尾的位置。
  3. 使用另一个循环,遍历字符串t,将其每个字符追加到字符串s的末尾。
  4. 在连接后的字符串末尾添加空字符\0,以标记字符串的结束。
  5. 返回连接后的字符串s

C语言版本:

char *str_cat(char *s, char *t) 
{
    char *p = s;
    while (*p) 
    { 
        p++;
    }
    while (*t) 
    { 
        *p++ = *t++;
    }
    *p = '\0'; 
    return s; 
}

总结:

 

该函数通过指针操作实现了两个字符串的拼接。首先,使用一个循环找到字符串s的末尾位置,然后使用另一个循环将字符串t的每个字符追加到字符串s的末尾。最后,在连接后的字符串末尾添加空字符\0,以标记字符串的结束。函数返回连接后的字符串s

你可能感兴趣的:(c++,算法,开发语言)