gpt4 book ai didi

java - 为使用 arraylist.contains 的算法找到大哦符号

转载 作者:行者123 更新时间:2023-11-29 10:18:42 24 4
gpt4 key购买 nike

我正在学习大哦符号。对于下面的代码,我有一个计算单词数量的程序,跳过分隔符。对于这个算法,for 循环将针对句子的长度,然后还有迭代到字符串的 contains。所以根据我的说法,这个算法的大哦符号是 O(n^3)。这是正确的还是我遗漏了一些关于大 Oh 符号的信息?

public class wordCount {

/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
String sentence = "How are you,zak;far: mon. day ?:";
int count = 1;
ArrayList<Character> delim = new ArrayList<Character>();
delim.add(' ');
delim.add(',');
delim.add('.');
delim.add(':');
delim.add(';');
delim.add('"');
delim.add('\'');
for (int i = 0; i != sentence.length() - 1; i++) {
if (delim.contains(sentence.charAt(i))) {
if (!delim.contains(sentence.charAt(i + 1))) {
count++;
}
}
}
System.out.println("The count is: " + count);
}
}

最佳答案

不,您不太正确 - 您假设 contains 的 O(n) 中的“n”与您感兴趣的“n”相同. 它不是——它是数组列表的长度。在这种情况下,这是定界符的数量,而不是句子的长度。

所以您的算法实际上是 O(N * M),其中 N 是句子长度,M 是定界符的数量。如果您将定界符集视为常量且仅将您的句子作为输入,则整个算法的复杂度为 O(N)。

即使您第二次有条件地调用 contains,每次迭代的 contains 调用总数也只有 1 或 2 - 它不能增长到(比如) 分隔符的数量或句子的大小。

关于java - 为使用 arraylist.contains 的算法找到大哦符号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11085259/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com