利用C语言的库函数strlen()、strcpy()和strcat(),编写算法int strInsert(char str1,char str2,int index),其功能是将串str2插入到str1的第index个位置上。若i大于S的长度,则插入操作不执行
题目分析:
我们可以想象最终字符串的样子,可以将它分成三段,第一段:str1在index之前的子字符串;第二段:str2的所有字符串;第三段:str1在index之后的子字符串。
首先,我们可以使用在str1的index的位置添加结束符‘\0’,这样就能得到第一段,但是这样做了之后,第三段会丢失,我们将无法得到,所以在此之前,我们先要将str1中index之后的子字符串保存到新数组strTemp中,进行这两步,我们就得到了第一段和第三段。
明显第二段不用我们去获得,str2直接就是第二段
那么接下来就是字符串拼接的问题啦,我们用到strcat_s安全函数,关于VS的线性安全函数的讲解我会专门出一篇文章,在这里只给大家介绍一下strcat_s的用法:
strcat_s函数具有三个参数:1.字符串(前字符串),2.连接的字节大小,3.字符串(后字符串)
功能是将两个字符串连接起来,注意它的返回值不是一个字符串,而是errno_t类型的,你只要知道拼接好的字符串就是第一个参数里面的字符串就行
接着我们再来讨论该怎样连接,经过上面的操作我们已经把str1变成只有index之前的字符串啦,所以接下来我们将str2拼接到后面,然后再把strTemp中的字符串(str1中index后的字符串)连接到后面,于是字符串插入成功
图例演示:
代码实现:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
/*字符串插入函数,成功返回1,否则返回0*/
int strInsert(char *str1, char *str2, int index)
{
int len1 = strlen(str1); //str1 的长度
if (len1 < index) //如果str1的长度没有index大,不操作
return 0;
char strTemp[200]; //存放str1中i位置后面的字符串
int number = 0;
for (int i = index; i < len1; i++)//赋值index位置后面的字符串到strTemp中
strTemp[number++] = str1[i];
strTemp[number] = '\0';
str1[index] = '\0'; //添加结束符,将str1变成只有index位置前面部分
strcat_s(str1,200,str2);//将str2的所有字符连接到str1后面
strcat_s(str1, 200,strTemp);
return 1;
}
int main()
{
char str1[200];
char str2[100];
printf("请输入str1:");
gets_s(str1);
printf("请输入str2:");
gets_s(str2);
int index;
printf("请输入插入位置:");
scanf_s("%d", &index);
if (strInsert(str1, str2,index))
printf("%s\n", str1);
else
printf("index大于str1的长度,操作失败!\n");
system("pause");
return 0;
}
运行结果:
测试一
测试二
测试三
拓展:
如果要将一个字符插入到字符串指定位置该怎么办呢?
提示:可利用字符串插入到字符串模板求解
代码编译器:Visual Studio 2017
ok,拜拜