Я прочитал этот вопрос о том, почему это невозможно, но не нашел решения проблемы.
Я хотел бы получить элемент из .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). Единственный способ получить элемент из a HashSet<T>
- это перечислить все элементы, равные O (n).
Я не нашел никакого решения этой проблемы, кроме как создать свой собственный HashSet<T>
или использовать Dictionary<K, V>
. Есть еще идеи?
Примечание:
я не хочу проверять, HashSet<T>
содержит ли элемент. Я хочу получить ссылку на элемент, который хранится в, HashSet<T>
потому что мне нужно его обновить (без замены другим экземпляром). Элемент, который я передал TryGetItem
бы, будет равен (в соответствии с механизмом сравнения, который я передал конструктору), но это не будет та же ссылка.