[解決済み] IEnumerable.Intersect()による複数リストの交わり
質問
以下のようなリストの交点を求めることができます。
var list1 = new List<int>() { 1, 2, 3 };
var list2 = new List<int>() { 2, 3, 4 };
var list3 = new List<int>() { 3, 4, 5 };
var listOfLists = new List<List<int>>() { list1, list2, list3 };
// expected intersection is List<int>() { 3 };
IEnumerable.Intersect()を使って何か方法はないでしょうか?
EDIT
私はこれに関してより明確であるべきでした。私は本当にリストのリストを持っています、私はそれがいくつになるのかわかりません、上記の3つのリストは単なる例でした、私が持っているものは、実際には
IEnumerable<IEnumerable<SomeClass>>
解決策
多くの素晴らしい回答をありがとうございました。これを解決するための選択肢は4つあることがわかりました。 リスト+集計 (@Marcel Gosselin)です。 リスト+foreach (@JaredPar, @Gabe Moothart)です。 HashSet+aggregate (@jesperll) と HashSet+foreach (@Tony the Pony)である。私はこれらの解決策についていくつかのパフォーマンステストを行いました(さまざまな リストの数 , 要素数 というように、各リストの 乱数の最大値 の大きさを指定します。
ほとんどの状況で、HashSetはListよりも性能が良いことがわかりました(HashSetの性質上、大きなリストと小さな乱数サイズを除いて、だと思いますが)。 foreachメソッドとaggregateメソッドの間に本当の違いは見つかりませんでした(foreachメソッドでは をわずかに の方が良い)。
私にとって、集計方法は本当に魅力的です(そして、私はそれを受け入れられた答えとします)が、最も読みやすい解決策とは言えません...。みなさん、本当にありがとうございます。
どのように解決するのですか?
どうでしょう。
var intersection = listOfLists
.Skip(1)
.Aggregate(
new HashSet<T>(listOfLists.First()),
(h, e) => { h.IntersectWith(e); return h; }
);
このように、全体を通して同じHashSetを使用することで最適化され、なおかつ1つのステートメントで済みます。ただ、listOfListsは常に少なくとも1つのリストを含んでいることを確認してください。
関連
-
[解決済み】ORA-01008: すべての変数がバインドされていません。これらはバインドされています。
-
[解決済み】HRESULTからの例外:0x800A03ECエラー
-
[解決済み】2つ(またはそれ以上)のリストを1つに統合する(C# .NETで
-
[解決済み】エラー「必要なフォーマルパラメータに対応する引数が与えられていない」を解決する?
-
[解決済み】Unityでゲームオブジェクトのすべての子をループスルーして破壊する方法?
-
[解決済み] 複数の例外を一度にキャッチする?
-
[解決済み] LINQで複数の "order by "を使用する
-
[解決済み] 複数の列でグループ化する
-
[解決済み] LINQで.Firstと.FirstOrDefaultを使用するタイミングは?
-
[解決済み】C#のvarキーワードの使い方
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] エンティティタイプ ApplicationUser は、現在のコンテキストのモデルの一部ではありません。
-
[解決済み] 'SubSonic.Schema .DatabaseColumn' 型のオブジェクトをシリアライズする際に、循環参照が検出されました。
-
[解決済み】非静的メソッドはターゲットを必要とする
-
[解決済み】値が期待した範囲に収まらない
-
[解決済み] 'IEnumerable<SelectListItem>' 型の ViewData アイテムで、キーが国であるものは存在しない。
-
[解決済み】Unity 「関連するスクリプトを読み込むことができません」「Win32Exception: システムは指定されたファイルを見つけることができません"
-
[解決済み】Linq 構文 - 複数列の選択
-
[解決済み】2年前のMSDateを把握する【クローズド
-
[解決済み】ファイルやアセンブリ、またはその依存関係の1つをロードできませんでした。
-
VSでscanfエラーを恒久的に解決するには、ソースファイルを作成し、自動的に#define _CRT_SECURE_NO_WARNINGS 1を追加してください。