に 1 回だけ出現する文字列の数を見つけようとしていますArrayList
。
これを何回達成できますか (可能な限り最高の時間計算量で)。
以下は私の方法です:
public static int countNonRepeats(WordStream words) {
ArrayList<String> list = new ArrayList<String>();
for (String i : words) {
list.add(i);
}
Collections.sort(list);
for (int i = 1; i < list.size(); i++) {
if (list.get(i).equals(list.get(i - 1))) {
list.remove(list.get(i));
list.remove(list.get(i - 1));
}
}
System.out.println(list);
return list.size();
}
list.get(i)
との文字列を削除しないのはなぜlist.get(i-1)
ですか?