解题思路:简单讲就是讲str2的字符添加到str1最后一个字符之后或者建立一个新的字符串str3来存放str1和str2,这个字符串的长度为两者字符个数之和再加1(这个长度使用strlen()函数取的),然后将str1和str2的字符放到str3中。

注意事项:字符串更新完后要加上字符串结束字符:'\0'.

参考代码:

方法一:

#include<stdio.h>

#include<string.h>

void strLink(char str1[], char str2[]);

int main()

{

     char str1[10],str2[10];

     scanf("%s\n", str1);

     scanf("%s", str2);

     strLink(str1, str2);

     puts(str1);

     return 0;

}

void strLink(char str1[], char str2[])

{

     int n1 = strlen(str1);

     int n2 = strlen(str2);

     for (int i = n1,j = 0; j < n2; j++, i++)

     str1[i] = str2[j];

     str1[n1 + n2] = '\0';    // 切记一定要添加结束字符。 

}


方法二:

#include<stdio.h>

#include<string.h>

#include<stdlib.h>

void strLink(char str1[], char str2[],char str3[]);

int main()

{

     char str1[10],str2[10];

     scanf("%s\n", str1);

     scanf("%s", str2);

     int m1 = strlen(str1);

     int m2 = strlen(str2);

     int m = m1 + m2 + 1;

     char *str3;

     str3 = (char *)malloc(m*sizeof(char));  //这个是没办法,不支持变长数组,只能用动态的了。

     strLink(str1, str2,str3);

     puts(str3);

     free(str3);

     return 0;

}

void strLink(char str1[], char str2[],char str3[])

{

     int n1 = strlen(str1);

     int n2 = strlen(str2);

     int i,j;

     for (i = 0; i < n1; i++)

     str3[i] = str1[i];

     for (i = 0, j = n1; i < n2; i++, j++)

     str3[j] = str2[i];

     str3[j] = '\0';

}

实测两种方法都通过。

点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论