php エディター Baicao は、Java アルゴリズムに関する素晴らしい Q&A を提供しました: 2 つの 2 次元リスト内の重複要素をチェックするにはどうすればよいですか?これは、多くの Java プログラマーが日常の開発でよく遭遇する問題の 1 つです。この記事の議論と分析を通じて、読者はさまざまなソリューションと最適化戦略について学び、Java プログラミングにおける同様の問題に対処するための方法とテクニックをより深く理解し、習得することができます。
2 つの listdc4b5854fa094b5d08a57a86ff781edf> (a と b とします) が与えられました。
返される値:mapdc4b5854fa094b5d08a57a86ff781edf、listdc4b5854fa094b5d08a57a86ff781edf>>
実際には、a と b のリストの長さは少なくとも 100,000 を超えます。 list.contains を使用してこのアプローチを試しましたが、最悪の場合の時間計算量は o(n^3) でした。
これが私のコードです。このアルゴリズムの時間計算量を o(n^2) 以下に削減したいと考えています。
define a and b as follows: a = [a, b, c], [d, e, f], [a, d, f] b = [a, d], [a], [c], [x] it returns : key value [a,d] | [a,b,c],[d,e,f],[a,d,f] [a] | [a,b,c],[a,d,f] [c] | [a,b,c] [x] | empty list回避策
未満に減らす方法があるかどうかはわかりませんが、# に減らすには##o( n^2) では、
hashmap を通じて list.contains
o(n)<code> .get
を削減できます。つまり o(1)
時間の複雑さ。
contains
a 内の要素のインデックスを探すことをお勧めします。
b 要素はそのインデックスを取得し、
a 対応リスト。
まず、
a
map を構築します。
リーリー
これは
ainset
リーリー
次に、
b
a の対応する要素を取得します。
たとえば、
[a, d]
[0, 1, 2] があります。これはコードです
リーリー
以上が2 つの 2D リスト アルゴリズムの重複をチェックしていますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。