通过此题,可以深刻的理解HashSet的特性,就是不能添加重复的值
hashset添加种类一个循环就搞定,然后判断如果 种类>一半?一半:种类;
答案:
public static int DistributeCandies(int[] candies)
{
HashSet<int> kinds = new HashSet<int>();
for (int i = 0; i < candies.Length; i++)
kinds.Add(candies[i]);
return kinds.Count() >= candies.Count() / 2 ? candies.Count() / 2 : kinds.Count;
}
调用:
public static void Main(string[] args)
{
int[] t = new int[] { 1, 1, 2, 2, 3, 3,3,3 };
int ss=DistributeCandies(t);
Console.WriteLine(ss);
Console.ReadKey();
}