RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1408319
Accepted
nx4n
nx4n
Asked:2022-07-10 15:09:29 +0000 UTC2022-07-10 15:09:29 +0000 UTC 2022-07-10 15:09:29 +0000 UTC

C、strstr的类比和字符串中子串的出现次数

  • 772

该程序将 1 个参数作为子字符串,然后是字符串。如果后续行中有子字符串,则需要显示此行以及其中子字符串的出现次数:

#include <stdio.h>

char *sub_string(const char *str, const char *s_str); /*str - строка, s_str - подстрока*/

int main(int argc, char **argv)
{
        int i, count, ssl;
        char *str;
        argv++;
        if(argc < 2){
                fprintf(stderr, "Incorrect args\n");
                return 1;
        }
        for(ssl = 0; (*argv)[ssl]; ssl++); /*ssl = (длина подстроки с '\0' символом) - 1*/
        puts("Args with substring:");
        for(i = 1; argv[i]; i++){
                count = 0;
                str = argv[i];
                while(sub_string(str, *argv)){
                        count++;
                        str += ssl;
                }
                if(count > 0)
                        printf("%s, substring's count: %d\n", argv[i], count);
        }
        return 0;
}

char *sub_string(const char *str, const char *s_str)
{
        char *str_ptr, *s_str_ptr;
        int trigger;
        while(*str){
                if(*str == *s_str){
                        trigger = 1;
                        str_ptr = str;
                        s_str_ptr = s_str;
                        while(*str_ptr && *s_str_ptr){
                                trigger &= (*str_ptr == *s_str_ptr);
                                str_ptr++;
                                s_str_ptr++;
                        }
                        if(trigger && !(*str_ptr) && *s_str_ptr)
                                return NULL;
                        if(trigger)
                                return str;
                }
                str++;
        }
        return NULL;
}

问题:

当我使用以下参数调用程序时:./prog "asd" "1asd2asd3asd"它给了我1asd2asd3asd, substring's count: 4. 为什么???

如果在一个循环中

                    while(sub_string(str, *argv)){
                            printf("%s\n", sub_string(str, *argv));
                            count++;
                            str += ssl;
                    }

добавить printf("%s\n", sub_string(str, *argv));

那么输出将是:

asd2asd3asdd
asd3asdd
asdd
asdd

为什么有asdd两次???3 次迭代后,d 应该保留并且函数应该返回 NULL,但它似乎又需要 asdd ...

当我打电话时,./prog "asd" "1asd2asdd"它给了我1asd2asdd, substring's count: 2。怎么了?我不明白前面的(和类似的例子)的例子有什么问题......这里Printf循环中的同一个例子会给出

asd2asdd
asdd

也就是说,一切都是应有的。我已经累了,胡说八道)))

c
  • 1 1 个回答
  • 52 Views

1 个回答

  • Voted
  1. Best Answer
    KoVadim
    2022-07-10T16:29:34Z2022-07-10T16:29:34Z

    我将回答第一个问题 - 为什么它会找到 4 行。一切都非常简单,极其简单。事实上,您的代码正在查看是否存在从字符串开头开始的字符串。如果找到,它会添加子字符串的长度并再次检查。取原始字符串“1asd2asd3asd”。显然,从字符串的开头有一个子字符串 asd。现在我们移动了 3 个字符(asd 的长度),我们有了字符串“d2asd3asd”(也在那里)。然后我们继续前进并有“sd3asd”(再次找到),最后一次迭代给出“asd”,你瞧——又找到了。这就是来龙去脉。该怎么办?有几个选项,但最简单的是简单地检查找到的子查询的位置并添加它。那就是它所在的地方

                str = argv[i];
                char * f = NULL; // инициализируем
                while((f = sub_string(str, *argv))){
                        count++;
                        // f хранит указатель, где нашли подстроку
                        str = f + ssl;
                        printf("str = %s\n", str);
                }
    

    但也许,如果要搜索的子字符串是adad,而我们要去的字符串是adadad,那么我们仍然需要仔细考虑正确答案应该是什么。我仍然得到 1,尽管有人可能会说应该有两个。但这很容易通过更换线路来解决

    str = f + ssl;
    

    每行

    str = f + 1;
    

    如何正确地做取决于你。

    我试图用最少的编辑来修复代码。一般来说,搜索功能中会有一些臭代码——比如这一行str_ptr = str;——在左边—— char*,在右边—— const char*。

    • 2

相关问题

  • free 出于某种原因不会从内存中删除数组

  • 请帮助代码

  • 为什么 masm 对字符串或文本文字太长发誓,为什么在结构中设置 db 或 dw?

  • 如何将数字拆分为位并将其写入 C 中的数组?

  • 如何以给定的角度移动物体?

  • 解决“子集和问题”的时效算法

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5