鱼C论坛

 找回密码
 立即注册
查看: 1043|回复: 6

[已解决]一道C语言函数题,真的顶不住了!

[复制链接]
发表于 2021-1-15 14:47:29 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
主函数中输入一个字符串str,再输入一个字符ch和一个正整数m,调用insertChar函数把ch插入到字符串str的第m位(从1开始计数)。请完成InsertChar函数的定义
输入样例
Hell world
o 5
输出样例
Hello world




需要拼接的源代码第一部分
#include "stdio.h"
#include "string.h"
void insertChar(char str[], char ch,int n);
int main()
{
    char str[20];
    gets(str);
    char ch;
    int n;
    scanf("%c%d",&ch,&n);
    insertChar(str,ch,n);
    puts(str);
    return 0;
}
最佳答案
2021-1-15 15:20:58
void insertChar(char str[] , char ch , int n)
{
        int i                                                       ;
        for(i = strlen(str) ; i > n - 2 ; i --) str[i + 1] = str[i] ;
        str[n - 1] = ch                                             ;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-1-15 15:07:50 | 显示全部楼层
看下这个https://zhidao.baidu.com/question/712193735370778525.html
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-15 15:20:58 | 显示全部楼层    本楼为最佳答案   
void insertChar(char str[] , char ch , int n)
{
        int i                                                       ;
        for(i = strlen(str) ; i > n - 2 ; i --) str[i + 1] = str[i] ;
        str[n - 1] = ch                                             ;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-1-15 16:19:27 | 显示全部楼层

思路能大概说一下吗,谢谢了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-15 16:28:06 | 显示全部楼层
FC_YSN 发表于 2021-1-15 16:19
思路能大概说一下吗,谢谢了

      把字符串 str 从插入点 str[n - 1] 到字符串结束字符 '\0' 之间的所有字符整体向后挪动 1 个字符,然后,把需要插入的字符复制到 str[n - 1] 的位置就好了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-1-15 16:31:27 | 显示全部楼层
jackz007 发表于 2021-1-15 16:28
把字符串 str 从插入点 str[n - 1] 到字符串结束字符 '\0' 之间的所有字符整体向后挪动 1 个字符, ...

for循环当中,i < n - 2 是怎么来的?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-1-15 16:38:47 | 显示全部楼层
本帖最后由 jackz007 于 2021-1-15 16:43 编辑

     题目要求的插入点是从 1 开始计数,所以,这个插入点用索引值来描述,那就是 n - 1。
     因为插入点的索引是 n - 1, 我得把包括索引 n - 1 在内的所有字符一起向后移动,就是说,n - 1 必须包括在移动范围之内。所以,循环条件必须是 i > n - 2。这样,i = n - 1 时还在循环,i = n - 2 时,循环终止。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-12 04:03

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表