C ++
 Computer >> コンピューター >  >> プログラミング >> C ++

C++の森のウサギ


森の中で、それぞれのウサギが色を持っているとしましょう。これで、ウサギのサブセット(おそらくすべて)が、同じ色の他のウサギの数を教えてくれます。それらの答えは配列に配置されます。森にいる可能性のあるウサギの最小数を見つける必要があります。したがって、入力が[1,1,2]の場合、出力は5になります。これは、「1」と答えた2匹のウサギが同じ色、たとえば白である可能性があるためです。これで、「2」と答えたウサギを白くすることはできません。そうしないと、答えに一貫性がなくなります。 「2」と答えたウサギが黒だったとしましょう。次に、配列に応答しなかった他の2匹の黒いウサギが森にいるはずです。したがって、森の中のウサギの可能な最小数は5:3で、答えたのは2で、答えなかったのは2です。

これを解決するには、次の手順に従います-

  • マップmを作成し、n:=配列ansのサイズ
  • retを0に設定
  • 0からn–1の範囲のiの場合
    • x:=ans [i]
    • x =0の場合、retを1増やし、この反復の次の部分をスキップします。
    • mにxがある場合は、retを(x + 1)増やし、m [x]:=0に設定します
    • それ以外の場合
      • m[x]を1増やします
      • m [x] =xの場合、mからxを削除します
  • return ret

理解を深めるために、次の実装を見てみましょう-

#include <bits/stdc++.h>
using namespace std;
class Solution {
   public:
   int numRabbits(vector<int>& ans) {
      map <int, int> m;
      int n = ans.size();
      int ret = 0;
      for(int i = 0; i < n; i++){
         int x = ans[i];
         if(x == 0){
            ret++;
            continue;
         }
         if(!m.count(x)){
            ret += (x + 1);
            m[x] = 0;
            }else{
               m[x]++;
           if(m[x] == x){
               m.erase(x);
            }
         }
      }
      return ret;
   }
};
main(){
   vector<int> v = {1,1,2};
   Solution ob;
   cout << (ob.numRabbits(v));
}

入力

[1,1,2]

出力

5

  1. C++での質素な数

    この問題では、正の整数Nが与えられます。私たちのタスクは、与えられた数が質素な数であるかどうかをチェックするプログラムを作成することです。 不正な番号 −指定された数の素因数分解の桁数よりも厳密に桁数が多い数。 例 − 625、数625の素因数は5 4です。 。 625の桁数は3です。 5 4の桁数 は2です。 3は厳密に2より大きくなります。したがって、625は質素な数です。 最初のいくつかの質素な数は − 125、128、243、256、343、512、625など。 問題を理解するために例を見てみましょう Input: n = 128 Output: Frugal n

  2. C++五胞体数

    五胞体数は、パスカルの三角形の5番目の数として表されます。ご存知のように、これは5番目の数字です。つまり、パスカルの三角形に少なくとも5つの数字が必要です。したがって、このシリーズの最初の数字は 1 4 6 4 1から始まります。 パスカルの三角形の4行目。したがって、このチュートリアルでは、たとえば、n番目の五胞体数を見つける必要があります Input : 1 Output : 1 Input : 4 Output : 35 次の図から出力を確認できます- この問題については、可能な限り、これは一種のシリーズであるため、ソリューションでこのシリーズのパターンを見つけようと