用C ++分发糖果

假设我们有一个长度相等的数组,这里数组中的不同数字代表不同种类的糖果。现在,每个数字表示一个相应种类的糖果。我们必须向兄弟姐妹平均分配糖果。我们必须找到姐姐可以接受的最大种类的糖果。

因此,如果输入类似于[1,1,2,3],则输出将为2,就好像我们认为姐妹有糖果[2,3]而兄弟有糖果[1,1]。现在,姐姐有两种不同的糖果,哥哥只有一种糖果。

为了解决这个问题,我们将遵循以下步骤-

  • 定义一组

  • 对于初始化i:= 0,当i <糖果大小时,更新(将i增加1),执行-

    • 将糖果[i]插入s

  • 返回s和糖果大小的最小值/ 2

例 

让我们看下面的实现以更好地理解-

#include <bits/stdc++.h>
using namespace std;
class Solution {
public:
   int distributeCandies(vector<int>& candies){
      unordered_set<int> s;
      for (int i = 0; i < candies.size(); i++)
         s.insert(candies[i]);
      return min(s.size(), candies.size() / 2);
   }
};
main(){
   Solution ob;
   vector<int> v = {1,1,2,3};
   cout << (ob.distributeCandies(v));
}

输入项

{1,1,2,3}

输出结果

2