DaiMaDaiMaDaiMaDaiMa
2020-01-09 21:16
采纳率: 100%
浏览 205

怎么写这道c语言编程题啊?

编写程序。
1、实现新建程序。
2、编辑文件。
编辑命令包括
L n 显示第n行
D n 删除第年行
CU n m 将第n行复制到第m行上面
CD n m 将第n行复制到第m行下面
RA str1 str2 将文件中的所有str1用str2替换
R x y n str1 str2将文件中的第x行,第y列开始的n个字符中的所有str1用str2替换。
I x y str 在第x行,第y列字符前插入str
DAStr str 删除将文件中的所有str
DStr x y n str 删除文件中的第x行,第y列开始的n个字符中的所有str。

万分感谢。

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

2条回答 默认 最新

  • Kim_小星兴 2020-01-09 23:52
    已采纳

    更新上传网址:

    https://github.com/KimAlittleStar/lightEdit

    • 运行程序并查看命令列表

      可用命令列表

    • 打开文件并显示内容

      打开文件显示内容

    • 将所有小写字母 a 更改为 A

      替换

    • 退出和其他功能展示

      退出程序

    今天下午想回答你那个有积分的回答,但是写到一半浏览器崩了~在刷新看到了有人已经在要采纳了~我就没有重新写了

    解决此问题两步走

    1. 实现对文件内容的操作
      2.将字符串转换为对应的函数执行

    内容细化

    1.1 fileIO流的实现

    1.2 存储每行的文本内容

    1.3 对文本内容进行处理(删除/追加等)

    2.1 识别命令(L D等等)

    2.2 识别命令后面的参数 (n 字符串str等等)

    2.3 根据识别到对应命令后执行对应的操作

    方案参考

    题目中有9个要求,那么也就是说你可以写成九个函数;

    例如 R这个命令你就可以将这所有的操作写到一个名为replace(int startLine,int startRow,int lengh,char* desStr,char* srcStr);这个函数中
    那么当需要执行R 操作时对应调用参数就好啦;

    如何操纵IO流文件这个可以寻求百度的帮助~

    如何解析字符串将其装换为命令你可以使用 scanf来做,其实sscanf更加好一些,如果你了解scanf,那么你可以尝试使用sscanf;

    如果你的水平还不错,或者你认为你其实可以实现这里的所有功能,那么你可以使用我的两个模块,他会帮助你更快的完成目标

    1. 字符串调用函数模块,可以像linux命令行一样调用对应函数 类似于 add 3 4 //will show "7"

    Github网址: https://github.com/KimAlittleStar/ExternFunc

    教程网址: https://blog.csdn.net/qq_39575645/article/details/103867598

    1. C语言实现的STL 标准容器,已经实现了replace和remove函数,基本的字符修改都可以实现了,二期非常方便使用行管理
      GitHub地址:https://github.com/KimAlittleStar/cstd/tree/release
      文章介绍:https://blog.csdn.net/qq_39575645/article/details/103867603

    建议

    软件要自己写才有成就感哦.你可以百度各种小问题如何解决然后拼凑到一起组成你自己的成果~~

    尝试自己解决每一个小问题才是一个合格的coder;

    如果实在不会的话留言评论我~我如果周末有时间就写一下发在博客里;

    但是也不一定会写哦~毕竟都是爱好;

    如果我写了要个点赞关注不过分吧? [滑稽]

    点赞 评论
  • 九头蛇daze 2020-01-10 09:43

    几个功能函数:

    char text[100][256];
    int count = 0;
    
    void str_replace(char * cp, int n, char * str)//替换字符串
    {
        int lenofstr;
        char * tmp;
        lenofstr = strlen(str);
        //str3比str2短,往前移动 
        if (lenofstr < n)
        {
            tmp = cp + n;
            while (*tmp)
            {
                *(tmp - (n - lenofstr)) = *tmp; //n-lenofstr是移动的距离 
                tmp++;
            }
            *(tmp - (n - lenofstr)) = *tmp; //move '\0' 
        }
        else
            //str3比str2长,往后移动
            if (lenofstr > n)
            {
                tmp = cp;
                while (*tmp) tmp++;
                while (tmp >= cp + n)
                {
                    *(tmp + (lenofstr - n)) = *tmp;
                    tmp--;
                }
            }
            strncpy(cp, str, lenofstr);
    }
    
    char s4[256];
    char *insert(char *s1, char *s2, int n)//插入字符串
    {
        int len1 = 0, len2 = 0, j = 0, len3, k = 0;
        int i;
    
        char *s3 = s4;
        if (s1 == NULL)
            return NULL;
        if (s2 == NULL)
            return s1;
        len1 = strlen(s1);
        len2 = strlen(s2);
    
        if (n > len1)
            return NULL;
        for (i = 0; i < n; i++)
        {
            j++;
        }
        for (i = 0; i < len1; i++)
        {
            s4[k++] = s1[i];
        }
    
        for (i = 0; i < len2; i++)
            s1[j++] = s2[i];
    
        for (i = n; i < len1; i++)
            s1[j++] = s4[i];
    
        s1[j] = '\0';
    
    
        return s1;
    }
    
    char d[256];
    void DeletS(char *s1, const char *s2){//删除字符串
        char *p = s1, *q, *c;
        unsigned long n = strlen(s2);
    
        while (1) {
            q = strstr(p, s2);
            if (q == NULL)
                break;
            c = q + n;
            *q = '\0';
            strcpy(d, c);
            p = strcat(p, d);
        }
    }
    
    点赞 评论

相关推荐 更多相似问题