肯尼斯·里科《C和指针》第6章 指针(7)编程的练习:删除字符

时间:2024-01-23 11:23:20

肯尼斯·里科《C和指针》第6章 指针(6)编程的练习:查找字符-CSDN博客

2.编写一个函数,删除一个字符串的一部分。函数的原型如下:

int del_substr(char *str, char const *substr)

函数首先应该判断substr是否出现在str中。如果它并未出现,函数就返回0;如果出现,函数应该把str中位于该子串后面的所有字符复制到该子串的位置,从而删除这个子串,然后函数返回1。如果substr多次出现在str中,函数只删除第1次出现的子串。函数的第2个参数绝不会被修改。

举个例子,假定str指向ABCDEFG,如果substr指向FGH、CDF或XABC,函数应该返回0,str未作任何修改;如果substr指向CDE,函数就把str修改为指向ABFG,方法是把F、G和结尾的NUL字节复制到C的位置,然后函数返回1。不论出现什么情况,函数的第2个参数都不应该被修改。

a.不应该使用任何用于操纵字符串的库函数(如strcpy、strcmp等);

b.函数中的任何地方都不应该使用下标引用。

一个值得注意的地方是,空字符串是每个字符串的一个子串,在字符串中删除一个空子串字符串不会产生变化。

这道题书里也没有答案,下面是我自己写的:

#include<stdio.h>

int del_substr(char* str, char const  *substr)
{
    //先判断substr是否在str里面
    char* str_ptr;
    char* substr_ptr;
    char* str_cpy;

    printf("%s\n",str);
    for(str_ptr = str; *str_ptr != '\0'; str_ptr++){
        substr_ptr = substr;
        if(*str_ptr == *substr_ptr){
            while(*str_ptr == *substr_ptr && *str_ptr != '\0'){
                str_ptr++;
                substr_ptr++;
                if(*substr_ptr == '\0'){
                    printf("the deletion is %s",str_ptr);
                    return 1;
                }
            }
        }
    }
}

int main()
{
    char str[]="ABCDEFG";
    char const substr[]="CDE";
    del_substr(str,substr);
}

现在还差删除不知道怎么搞(唉),明天先把课上了,然后要把lab做了。。。如果有时间再回头看看——“方法是把F、G和结尾的NUL字节复制到C的位置,然后函数返回1”。。。