c#中的Hashset给出了一种奇怪的行为

yam*_*ini 0 c# memory-management hashset while-loop data-structures

我在C#中遇到HashSet问题....

这是我的代码:

  List<int> elements = new List<int>();
        for(int i = 0;i< 100000;i++)
        {
            elements.Add(i);
        }
        HashSet<int> c = new HashSet<int>();
        foreach(var ele in elements)
        {
        c.Add(ele);
        }

        Console.WriteLine("Working HashSet " + c.Count);

        var Numbers = new HashSet<int>();
        var mycount = 0;
        using (TextReader reader = File.OpenText(@"myfile.txt"))
        {
            while ((line = reader.ReadLine()) != null)
            {
                mycount++;
                int parsed = int.Parse(line);
                Numbers.Add(parsed);
            }
        }

        Console.WriteLine("my counter took" + mycount);

        Console.WriteLine("Bad HashSet" + Numbers.Count);
Run Code Online (Sandbox Code Playgroud)

工作HashSet 100 000

我的柜台拿了50万

Bad HashSet 9999

为什么第二个hashset没有添加50万个项目???? 这对我来说是个谜

Rob*_*ani 5

A HashSet不会添加重复的数字,因为这是设置工作的方式.

例如,假设这些是前几行myfile.txt:

1
2
3
1
2
3
4
Run Code Online (Sandbox Code Playgroud)

您将迭代7个值,但这些行中只有4个唯一数字,而HashSet不会添加1,2或3的重复数.在您的情况下,您有500,000行但只有9,999个唯一数字.

  • 您可以查看"添加"方法的(bool)结果,以查看该数字是否已添加(true)或未添加(false),因为它已存在. (2认同)