当前位置: 首页 > 知识库问答 >
问题:

断字时间复杂度

敖子安
2023-03-14

我遇到了单词中断问题,它是这样的:

给定一个输入字符串和一个字典,如果可能,将输入字符串分割成一个空间分隔的字典单词序列。

然而,在Quora中,一个用户发布了一个线性时间解决方案

我不知道它怎么会是线性的。他们在时间复杂度计算上有什么错误吗?这个问题的最佳可能最坏情况时间复杂度是多少。我在这里发布了最常见的DP解决方案

String SegmentString(String input, Set<String> dict) {
    int len = input.length();
    for (int i = 1; i < len; i++) {
        String prefix = input.substring(0, i);
        if (dict.contains(prefix)) {
              String suffix = input.substring(i, len);
              if (dict.contains(suffix)) {
                  return prefix + " " + suffix;
              }
        }
    }
    return null;
}

共有1个答案

索曾琪
2023-03-14

您在这里链接的“线性”时间算法的工作方式如下:

如果字符串为SharperNeedle,而dictionary为Sharp,sharper,Needle

  1. 它在字符串中推入sharp
  2. 则会看到er不在字典中,但如果我们将其与最后添加的单词组合,则sharper存在。因此,它弹出最后一个元素并将其推入。

对于字符串eaterror和字典eat,eater,error,上述逻辑失败。

这里er将从列表中弹出eat,并推入EATER。剩余的字符串ror将不会被识别和丢弃。

关于您发布的代码,正如注释中提到的,这只适用于一个分区位置的两个单词。

 类似资料:
  • 以下代码的时间复杂度分析和空间复杂度分析是什么: 给定一个非空字符串和一个包含非空单词列表的字典,确定是否可以被分段为一个或多个字典单词的空格分隔序列。

  • 主要内容:时间复杂度,空间复杂度《 算法是什么》一节提到,解决一个问题的算法可能有多种,这种情况下,我们就必须对这些算法进行取舍,从中挑选出一个“最好”的。 算法本身是不分“好坏”的,所谓“最好”的算法,指的是最适合当前场景的算法。挑选算法时,主要考虑以下两方面因素: 执行效率:根据算法所编写的程序,执行时间越短,执行效率就越高; 占用的内存空间:不同算法编写出的程序,运行时占用的内存空间也不相同。如果实际场景中仅能使用少量的内

  • 假设T是具有n个节点和高度h的二叉查找树。T的每个节点x存储一个实数x。键。给出以下算法Func1(T. root)的最坏情况时间复杂度。你需要证明你的答案。 x.left() 对于最坏情况下的运行时,我认为这将是O(树的高度),因为这基本上类似于最小()或最大()二元搜索树算法。然而,它是递归的,所以我对是否将O(h)作为最坏的运行时编写有点犹豫。 当我考虑它时,最坏的情况是如果函数执行if(s

  • 有人能帮我了解一下这个代码片段的时间和空间复杂性吗?请参考leetcode问题-单词中断II。给定一个非空字符串s和一个包含非空单词列表的字典单词dict,在s中添加空格来构造一个句子,其中每个单词都是有效的字典单词。返回所有这些可能的句子。

  • 问题内容: 切片Python字符串的时间复杂度是多少?鉴于Python字符串是不可变的,我可以想象对它们进行切片或取决于切片的实现方式。 我需要编写一个遍历(可能很大)字符串的所有后缀的函数。我可以通过将后缀表示为整个字符串的元组和一个索引以开始从中读取字符来避免对字符串进行切片,但这很丑陋。相反,如果我天真地像这样写我的函数: … …将其时间复杂度是或,其中是? 问题答案: 简短的答案:通常是切

  • 我已经阅读了这么多的资源,但仍然无法理解什么是时间复杂性。我阅读的参考资料基于各种公式,我理解用于表示时间复杂性,但我不知道如何表示。谁能请解释这个原则,以一个可以理解的明确的方式请给我。