Computer >> 컴퓨터 >  >> 프로그램 작성 >> C++

C++로 사탕 배포


길이가 짝수인 배열이 있다고 가정하고 여기에서 이 배열의 다른 숫자는 다른 종류의 사탕을 나타냅니다. 이제 각 숫자는 해당 종류의 사탕 하나를 의미합니다. 우리는 사탕을 형제 자매에게 균등하게 나누어야 합니다. 우리는 자매가 받을 수 있는 사탕의 종류를 최대로 찾아야 합니다.

따라서 입력이 [1,1,2,3]과 같으면 자매에게 사탕[2,3]이 있고 형제에게 사탕[1,1]이 있는 것처럼 출력이 2가 됩니다. 이제 자매에게는 두 종류의 사탕이 있고 형제에게는 한 종류의 사탕만 있습니다.

이 문제를 해결하기 위해 다음 단계를 따릅니다. −

  • 한 세트 정의

  • 초기화 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