logo

Rand2() kullanarak Rand3()'u uygulayın

Eşit olasılıkla 0 veya 1 döndüren bir Rand2() fonksiyonu verildiğinde, eşit olasılıkla 0 1 veya 2 döndüren Rand2() işlevini kullanarak Rand3()'u uygulayın. Rand2() yöntemine yapılan çağrı sayısını en aza indirin. Ayrıca başka herhangi bir kütüphane fonksiyonunun ve kayan nokta aritmetiğinin kullanımına izin verilmez.
 

Java karma kümesi


Fikir ifadeyi kullanmaktır 2 * Rand2() + Rand2() . Eşit olasılıkla 0 1 2 3 değerini döndürür. Eşit olasılıkla 0 1 2 döndürmesini sağlamak için istenmeyen olay 3'ü ortadan kaldırırız.
Aşağıda yukarıdaki fikrin uygulanması yer almaktadır - 
 



C++
// C++ Program to print 0 1 or 2 with equal  // probability #include    using namespace std; // Random Function to that returns 0 or 1 with // equal probability int rand2() {  // rand() function will generate odd or even  // number with equal probability. If rand()  // generates odd number the function will  // return 1 else it will return 0.  return rand() & 1; }   // Random Function to that returns 0 1 or 2 with  // equal probability 1 with 75% int rand3() {  // returns 0 1 2 or 3 with 25% probability  int r = 2 * rand2() + rand2();    if (r < 3)  return r;    return rand3(); } // Driver code to test above functions int main() {  // Initialize random number generator  srand(time(NULL));    for(int i = 0; i < 100; i++)  cout << rand3();    return 0; } 
Java
// Java Program to print 0 1 or 2 with equal  // probability import java.util.Random;  class GFG {  // Random Function to that returns 0 or 1 with   // equal probability   static int rand2()   {   // rand() function will generate odd or even   // number with equal probability. If rand()   // generates odd number the function will   // return 1 else it will return 0.   Random rand = new Random();   return (rand.nextInt() & 1);   }   // Random Function to that returns 0 1 or 2 with   // equal probability 1 with 75%   static int rand3()   {   // returns 0 1 2 or 3 with 25% probability   int r = 2 * rand2() + rand2();   if (r < 3)   return r;   return rand3();   }   // Driver code  public static void main(String[] args) {  for(int i = 0; i < 100; i++)   System.out.print(rand3());  } } // This code is contributed by divyesh072019. 
Python3
# Python3 Program to print 0 1 or 2 with equal  # Probability import random # Random Function to that returns 0 or 1 with  # equal probability  def rand2(): # randint(0100) function will generate odd or even # number [1100] with equal probability. If rand() # generates odd number the function will  # return 1 else it will return 0 tmp=random.randint(1100) return tmp%2 # Random Function to that returns 0 1 or 2 with  # equal probability 1 with 75%  def rand3(): # returns 0 1 2 or 3 with 25% probability  r = 2 * rand2() + rand2() if r<3: return r return rand3() # Driver code to test above functions if __name__=='__main__': for i in range(100): print(rand3()end='') #This code is contributed by sahilshelangia 
C#
// C# Program to print 0 1 or 2 with equal  // probability  using System; class GFG  {  // Random Function to that returns 0 or 1 with   // equal probability   static int rand2()   {   // rand() function will generate odd or even   // number with equal probability. If rand()   // generates odd number the function will   // return 1 else it will return 0.   Random rand = new Random();   return (rand.Next() & 1);   }   // Random Function to that returns 0 1 or 2 with   // equal probability 1 with 75%   static int rand3()   {   // returns 0 1 2 or 3 with 25% probability   int r = 2 * rand2() + rand2();   if (r < 3)   return r;   return rand3();   }   // Driver code  static void Main()   {  for(int i = 0; i < 100; i++)   Console.Write(rand3());  } } // This code is contributed by divyeshrabadiya07. 
PHP
 // PHP Program to print 0 1 or  // 2 with equal probability // Random Function to that  // returns 0 or 1 with // equal probability function rand2() { // rand() function will generate  // odd or even number with equal  // probability. If rand() generates  // odd number the function will // return 1 else it will return 0. return rand() & 1; } // Random Function to that  // returns 0 1 or 2 with  // equal probability 1 with 75% function rand3() { // returns 0 1 2 or 3  // with 25% probability $r = 2 * rand2() + rand2(); if ($r < 3) return $r; return rand3(); } // Driver Code // Initialize random  // number generator srand(time(NULL)); for($i = 0; $i < 100; $i++) echo rand3(); // This code is contributed by aj_36 ?> 
JavaScript
<script>  // Javascript program to print 0 1 or 2 with equal   // probability    // Random Function to that returns 0 or 1 with  // equal probability  function rand2()  {    // Math.random()*2 function generates   // 0 and 1 with equal probability  return Math.floor(Math.random()*2);  }    // Random Function to that returns 0 1 or 2 with   // equal probability 1 with 75%  function rand3()  {    // returns 0 1 2 or 3 with 25% probability  var r = 2 * rand2() + rand2();    if (r < 3)  return r;  return rand3();  }    var ans = ''; //to store the output  for(var i = 0; i < 100; i++)  ans += rand3();    document.write(ans);    // This code is contributed by shruti456rawal </script> 

Çıkış :  
 

2111011101112002111002020210112022022022211100100121202021102100010200121121210122011022111020


Başka Bir Çözüm - 
Eğer x = Rand2() ve y = Rand2() ise x + y %25 olasılıkla 0 ve 2, %50 olasılıkla 1 değerini döndürecektir. 1'in olasılığını 0 ve 2'nin olasılığına, yani %25'e eşit kılmak için, x + y = 1 ile sonuçlanan, yani (x = 1 y = 0) veya (x = 0 y = 1) ile sonuçlanan istenmeyen bir olayı ortadan kaldırırız. 
 

int rand3() { int x y; do { x = rand2(); y = rand2(); } while (x == 0 && y == 1); return x + y; }


Lütfen yukarıdaki çözümlerin her çalıştırıldığında farklı sonuçlar üreteceğini unutmayın.