비가 내리는 사람 2022-02-25 14:21 采纳率: 100%
浏览 60
已结题

模拟strstr函数有一个小bug

const char* My_strstr(const char *long_str,const char short_str)
{
int long_str_i = 0;
int short_str_i = 0;
const char
start = NULL;

while ((long_str[long_str_i] != '\0') && (short_str[short_str_i] != '\0')) //判断长字符和短字符是否接收到‘\0’
{
    //外循环
    start = &long_str[long_str_i];   //定义从那个地方开始

    while (long_str[long_str_i] == short_str[short_str_i]) //内循环
    {
        long_str_i++;
        short_str_i++;
    }

    if (short_str[short_str_i] == '\0') //如果短字符接收到'\0'返回到起始位
    {
         return start;
    }
    
    start++;
    long_str_i=long_str_i+1; //长字符往后偏移
    //short_str_i =short_str+1;
    //short_str_i=0;//段字符串停止
}
return NULL; //返回

}

  • 写回答

4条回答 默认 最新

  • 关注

    这是判断短字符串是否在长字符中,并返回在长字符串中的位置吗?
    (1)外层while中的条件不需要判断短字符串。
    (2)每次循环,short_str_i 需要重置为0
    (3)内层while需要判断长字符和短字符串是否已经到结尾。
    代码修改如下:

    #include <stdio.h>
    
    const char* My_strstr(const char *long_str,const char* short_str)
    {
        int long_str_i = 0;
        int short_str_i = 0;
        const char *start = NULL;
    
        while ((long_str[long_str_i] != '\0') ) //判断长字符和短字符是否接收到‘\0’
        {
            //外循环
            start = &long_str[long_str_i];   //定义从那个地方开始
            short_str_i = 0;//这里重置0
            while (long_str[long_str_i]!='\0' &&short_str[short_str_i] !='\0' && long_str[long_str_i] == short_str[short_str_i]) //内循环
            {
                long_str_i++;
                short_str_i++;
            }
    
            if (short_str[short_str_i] == '\0') //如果短字符接收到'\0'返回到起始位
            {
                return start;
            }
    
            //start++;//这一句没用
            long_str_i=long_str_i+1; //长字符往后偏移
            //short_str_i =short_str+1;
            //short_str_i=0;//段字符串停止
        }
        return NULL; //返回
    }
    
    
    

    完整代码及测试代码如下:

    #include <stdio.h>
    
    const char* My_strstr(const char *long_str,const char* short_str)
    {
        int long_str_i = 0;
        int short_str_i = 0;
        const char *start = NULL;
    
        while ((long_str[long_str_i] != '\0') ) //判断长字符和短字符是否接收到‘\0’
        {
            //外循环
            start = &long_str[long_str_i];   //定义从那个地方开始
            short_str_i = 0;//这里重置0
            while (long_str[long_str_i]!='\0' &&short_str[short_str_i] !='\0' && long_str[long_str_i] == short_str[short_str_i]) //内循环
            {
                long_str_i++;
                short_str_i++;
            }
    
            if (short_str[short_str_i] == '\0') //如果短字符接收到'\0'返回到起始位
            {
                return start;
            }
    
            //start++;//这一句没用
            long_str_i=long_str_i+1; //长字符往后偏移
            //short_str_i =short_str+1;
            //short_str_i=0;//段字符串停止
        }
        return NULL; //返回
    }
    
    int main()
    {
        char longstr[100],shortstr[20];
        const char* p;
        scanf("%s %s",longstr,shortstr);
        p = My_strstr(longstr,shortstr);
        printf("%s",p);
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 3月7日
  • 已采纳回答 2月27日
  • 创建了问题 2月25日

悬赏问题

  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?