c#字典高效通过value找key
时间: 2024-02-02 20:03:46 浏览: 148
根据字典的value取它对应的key
4星 · 用户满意度95%
在 C# 中,如果需要高效地通过 value 找到 key,可以考虑使用双向字典库( `BiDictionary`)或使用 `HashSet`,但这两种方法都需要使用第三方库。如果希望使用标准库来实现高效的查找,可以考虑将字典的键值对颠倒一下,即将原字典中的键作为值,将原字典中的值作为键,然后再通过新的字典来查找。
以下是通过颠倒键值对来高效查找的示例代码:
```csharp
// 创建一个字典
Dictionary<string, int> dict = new Dictionary<string, int>();
dict.Add("apple", 1);
dict.Add("banana", 2);
dict.Add("cherry", 3);
// 颠倒键值对,创建新字典
Dictionary<int, string> reverseDict = new Dictionary<int, string>();
foreach (KeyValuePair<string, int> kvp in dict)
{
reverseDict.Add(kvp.Value, kvp.Key);
}
// 通过 value 找到 key
string key = null;
if (reverseDict.TryGetValue(2, out key))
{
Console.WriteLine("Key: " + key);
}
else
{
Console.WriteLine("Value not found in dictionary.");
}
```
在上述代码中,我们首先创建了一个 `Dictionary<string, int>`,并将一些键值对添加到其中。然后,我们使用 `foreach` 循环颠倒字典中的键值对,创建一个新的 `Dictionary<int, string>`。最后,我们使用 `TryGetValue` 方法在新字典中查找指定值对应的键,并输出找到的键或相应的错误消息。此方法的时间复杂度为 O(1),比上一个示例中的方法更高效。
阅读全文