私はビッグオー記法について学んでいます。以下のコードでは、区切り文字をスキップして単語数をカウントするプログラムがあります。このアルゴリズムの場合、for ループは文の長さに対して行われ、文字列に対して反復処理を行う含まれるものもあります。したがって、私によると、このアルゴリズムの大きな oh 表記は 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);
}
}