MENU

库函数编写插入函数

• November 1, 2020 • 串和数组

利用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,拜拜

Archives QR Code Tip
QR Code for this page
Tipping QR Code