用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