将字符串插入另一个字符串的指定位置

题目:编写一个函数,将一个字符串插入到另一个字符串的某个位置后面(例如:将”abc”插入到”abcdef”的第三个字符位置后面,结果为”abcabcdef”)。编写程序时,请在必要的地方加以注释(注:不能用该程序语言的内置函数或过程)。

思路:

  • 将str1字符串的指定位置后的内容复制到另一个字符串中,空间换时间降低时间复杂度;
  • 再将str2字符串(待插入字符串)复制到str1的指定位置;
  • 将str1和tmp拼接起来(这里用到了字符串拼接函数)。

代码实现:

#include <iostream>
#define Max_num 1000

int myStrlen(const char *str)
{
    int len = 0;
    while (*str++)
        len++;
    return len;
}

void myStrcat(char *str1, char *str2)  //拼接函数
{
    int len1 = strlen(str1);
    int len2 = strlen(str2);
    for (int i = 0;i < len2;i++)
    {
        str1[len1 + i] = str2[i];
    }
    str1[len1 + len2] = '\0';
}

void myLink(char *str1, char *str2,int pos)
{
    int len1 = myStrlen(str1);
    int len2 = myStrlen(str2);
    char *tmp= (char *)malloc(sizeof(char));
    int cnt = 0;
    for (int i = pos; i <= len1;i++) 
    {
        //*tmp++ = str1[i];    //指针要初始化或者有相应的值,这样是错误的
        tmp[cnt++] = str1[i];
    }
    int j;
    for ( j = 0;j < len2;j++)
    {
        str1[ pos + j] = *str2++;
    }
        str1[pos + j] = '\0';
        myStrcat(str1, tmp);
}

int main()
{
    char str1[Max_num], str2[Max_num];
    int n;
    while (cin>>str1>>str2)
    {
        cin >> n;
        myLink(str1, str2, n);
        cout << str1 <<endl;
    }
    return 0;
}
  • 9
    点赞
  • 54
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值