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

c语言编程
1,新建文本
2,编辑文本
编辑命令包括
L n 显示第n行
D n 删除第n行
CU 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.

这是几个功能函数:

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);
    }
}