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

C++で数値が高いか低いかを推測する


推測ゲームをプレイしているとします。このゲームの特性は次のとおりです-

プレーヤー1は1からnまでの数字を選びます。 player2は、私が選んだ番号を推測する必要があります。 player2が間違った推測をするたびに、player1はplayer2に数字が大きいか小さいかを知らせます。

次のように3つの可能な結果を​​返す関数guess(num)を使用できます-

  • -1-Player1の数が少ない

  • 1 −Player1の数が多い

  • 0 −番号が一致しています

したがって、入力がn =10、pick =5の場合、出力は5になります。

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

  • l:=1、r:=n

  • l − =rの場合、do −

    • m:=l +(r --l)/ 2

    • guess(m)が0と同じ場合、-

      • mを返す

    • guess(m)が-1と同じ場合、-

      • r:=m-1

    • それ以外の場合

      • l:=m + 1

  • 0を返す

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

#include <bits/stdc++.h>
using namespace std;
class Solution {
private:
   int number;
   int guess(int num){
      if(number > num)
         return 1;
      if(number < num)
         return -1;
      return 0;
   }
public:
   Solution(int n){
      number = n;
   }
   int guessNumber(int n) {
      int l=1,r=n,m;
      while(l<=r){
         m=l+(r-l)/2;
         if(guess(m)==0)
            return m;
         if(guess(m)==-1)
            r=m-1;
         else
            l=m+1;
      }
      return 0;
   }
};
main(){
   Solution ob(5); //pick = 5
   cout << (ob.guessNumber(10));
}

入力

5,10

出力

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 次の図から出力を確認できます- この問題については、可能な限り、これは一種のシリーズであるため、ソリューションでこのシリーズのパターンを見つけようと