您的位置:首页 >C# HashSet使用教程:高效存储不重复元素
发布于2026-01-07 阅读(0)
扫一扫,手机访问
HashSet<T>是C#中基于哈希表实现的去重集合,平均时间复杂度O(1),支持Add()添加(重复返回false)、Contains()查找、UnionWith()等集合运算,自定义类型需重写GetHashCode()和Equals()或使用record。

HashSet<T> 是 C# 中专门用于存储不重复元素的集合类型,底层基于哈希表实现,插入、删除、查找平均时间复杂度都是 O(1),比 List 或 Array 做去重快得多。
直接 new 一个泛型 HashSet,指定元素类型。添加用 Add() 方法,重复添加会自动忽略,且返回 false。
var set = new HashSet<string>();set.Add("apple"); // 返回 trueset.Add("apple"); // 返回 false,集合不变set.Add("banana"); // 返回 true用 Contains() 判断某个值是否已存在,效率很高。构造时也可以传入已有集合(如数组、List)来快速初始化,自动去重。
set.Contains("apple"); // truevar numbers = new HashSet<int>(new[] { 1, 2, 2, 3, 3 }); // 结果是 {1, 2, 3}HashSet 提供了原生支持的集合运算方法,无需手写循环,代码简洁又高效。
set1.UnionWith(set2); // 并集(set1 变成 set1 ∪ set2)set1.IntersectWith(set2); // 交集(set1 变成 set1 ∩ set2)set1.ExceptWith(set2); // 差集(set1 变成 set1 - set2)Union()、Intersect() 等静态扩展方法(需引用 System.Linq)如果存的是自定义类或结构体,必须确保它正确实现了 GetHashCode() 和 Equals(),否则重复判断会失效。推荐用 record 类型,或用 IEqualityComparer<T> 自定义比较逻辑。
var people = new HashSet<Person>(new PersonComparer());record Person(string Name, int Age); // record 默认按值比较,适合 HashSet基本上就这些。用 HashSet 存不重复数据,既省心又高效,关键点就是类型要可哈希、操作前想清楚要不要改原集合。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9