[解決済み] HashSet<T>から実際のアイテムを取り出すには?
質問
私が読んだのは この質問 を読みましたが、なぜそれができないのか、解決策は見つかりませんでした。
私は、.NETの
HashSet<T>
. このようなシグネチャを持つようなメソッドを探しています。
/// <summary>
/// Determines if this set contains an item equal to <paramref name="item"/>,
/// according to the comparison mechanism that was used when the set was created.
/// The set is not changed. If the set does contain an item equal to
/// <paramref name="item"/>, then the item from the set is returned.
/// </summary>
bool TryGetItem<T>(T item, out T foundItem);
このような方法でセットからアイテムを検索するのは O(1) となります。から項目を取り出す唯一の方法は
HashSet<T>
から項目を取り出す唯一の方法は、すべての項目を列挙することであり、これはO(n)です。
この問題に対する回避策は、自分で
HashSet<T>
を作るか、あるいは
Dictionary<K, V>
. 他のアイデアは?
注意してください。
をチェックするのではなく
HashSet<T>
にアイテムが含まれているかどうかをチェックしたいのではありません。に格納されているアイテムへの参照を取得したいのです。
HashSet<T>
に格納されているアイテムへの参照を取得したいのですが、 (別のインスタンスに置き換えることなく) そのアイテムを更新する必要があるからです。私が
TryGetItem
に渡す項目は (コンストラクタに渡した比較メカニズムによれば) 等しくなりますが、同じ参照ではありません。
どのように解決するのですか?
あなたが求めているものは .NET Core 1 年前 であり 最近、.NET 4.7.2 に追加されました。 :
.NET Framework 4.7.2 では、標準のコレクション型にいくつかの API を追加し、次のような新しい機能を実現しました。
- 'TryGetValue' が SortedSet と HashSet に追加され、他のコレクション タイプで使用される Try パターンに一致するようになりました。
署名は以下の通りです(.NET 4.7.2以降で見られます)。
//
// Summary:
// Searches the set for a given value and returns the equal value it finds, if any.
//
// Parameters:
// equalValue:
// The value to search for.
//
// actualValue:
// The value from the set that the search found, or the default value of T when
// the search yielded no match.
//
// Returns:
// A value indicating whether the search was successful.
public bool TryGetValue(T equalValue, out T actualValue);
P.S ...:一応、興味がある人は 関連の機能があり、将来的に追加される予定です。 - HashSet.GetOrAdd(T)があります。
関連
-
[解決済み】Visual studio 2019がデバッグ時にフリーズする件
-
[解決済み] 他のスレッドからGUIを更新するにはどうすればよいですか?
-
[解決済み] enumを列挙するには
-
[解決済み] intをenumにキャストするにはどうすればよいですか?
-
[解決済み] C#で文字列のエンコーディングを手動で指定せずに、一貫性のあるバイト表現を得るには?
-
[解決済み] DateTime型の誕生日から年齢を計算するにはどうしたらいいですか?
-
[解決済み] Microsoft Officeをインストールせずに、C#でExcel(.XLSおよび.XLSX)ファイルを作成するにはどうすればよいですか?
-
[解決済み] なぜList<T>を継承しないのですか?
-
[解決済み] HashSetの値を構造的に初期化する方法は?
-
[解決済み] コンストラクタのシグネチャを定義するインターフェース?
最新
-
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 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] [Entity Framework 4.1でエンティティに関連オブジェクトを追加する際に、エンティティオブジェクトをIEntityChangeTracker.の複数のインスタンスから参照できない。
-
[解決済み】文字列が有効な DateTime " format dd/MM/yyyy " として認識されなかった。
-
[解決済み】Sequence contains no matching element(シーケンスにマッチする要素がない
-
[解決済み】Swashbuckle/Swagger + ASP.Net Core: "Failed to load API definition" (API定義の読み込みに失敗しました
-
[解決済み] EntityTypeにキーが定義されていないエラー
-
[解決済み】「...は'型'であり、与えられたコンテキストでは有効ではありません」を解決するにはどうすればよいですか?(C#)
-
[解決済み] 2つのリストを結合する
-
[解決済み】インデックスが範囲外でした。コレクションパラメータname:indexのサイズより小さく、非負でなければなりません。
-
[解決済み】「namespace」なのに「type」のように使われる。
-
[解決済み】プロセスが実行されているかどうかを知るには?