Biorąc pod uwagę matrycę prostokątną, możemy przesunąć się z prądu w 4 kierunkach z równym prawdopodobieństwem. 4 kierunki to prawy lewy górny lub dolny dołu. Oblicz prawdopodobieństwo, że po n porusza się z danej pozycji (i j) w matrycy, nie przekroczymy granic matrycy w żadnym momencie.
boto3
Zdecydowanie zalecamy zminimalizowanie przeglądarki i najpierw spróbować tego.
Chodzi o to, aby wykonać coś podobnego do DFS. Rekurencyjnie przemierzamy w każdym z 4 dozwolonych kierunków i dla każdej spotkanej komórki obliczamy wymagane prawdopodobieństwo za pomocą jednego ruchu. Ponieważ każdy kierunek ma równe prawdopodobieństwo, każdy kierunek przyczyni się do 1/4 całkowitego prawdopodobieństwa tej komórki, tj. 0,25. Wracamy 0, jeśli wyjdziemy poza matrycę i zwrócimy 1, jeśli n kroki zostaną ukończone bez przekraczania granic macierzy.
Poniżej znajduje się wdrożenie powyższego pomysłu:
C++/// C++ program to find the probability // that we do not cross boundary of a // matrix after N moves. #include using namespace std; // check if (x y) is valid matrix coordinate bool isSafe(int x int y int m int n) { return (x >= 0 && x < m && y >= 0 && y < n); } // Function to calculate probability // that after N moves from a given // position (x y) in m x n matrix // boundaries of the matrix will not be crossed. double findProbability(int m int n int x int y int N) { // boundary crossed if (!isSafe(x y m n)) return 0.0; // N steps taken if (N == 0) return 1.0; // Initialize result double prob = 0.0; // move up prob += findProbability(m n x - 1 y N - 1) * 0.25; // move right prob += findProbability(m n x y + 1 N - 1) * 0.25; // move down prob += findProbability(m n x + 1 y N - 1) * 0.25; // move left prob += findProbability(m n x y - 1 N - 1) * 0.25; return prob; } // Driver code int main() { // matrix size int m = 5 n = 5; // coordinates of starting point int i = 1 j = 1; // Number of steps int N = 2; cout << 'Probability is ' << findProbability(m n i j N); return 0; }
C /// C program to find the probability // that we do not cross boundary of a // matrix after N moves. #include #include // check if (x y) is valid matrix coordinate bool isSafe(int x int y int m int n) { return (x >= 0 && x < m && y >= 0 && y < n); } // Function to calculate probability // that after N moves from a given // position (x y) in m x n matrix // boundaries of the matrix will not be crossed. double findProbability(int m int n int x int y int N) { // boundary crossed if (!isSafe(x y m n)) return 0.0; // N steps taken if (N == 0) return 1.0; // Initialize result double prob = 0.0; // move up prob += findProbability(m n x - 1 y N - 1) * 0.25; // move right prob += findProbability(m n x y + 1 N - 1) * 0.25; // move down prob += findProbability(m n x + 1 y N - 1) * 0.25; // move left prob += findProbability(m n x y - 1 N - 1) * 0.25; return prob; } // Driver code int main() { // matrix size int m = 5 n = 5; // coordinates of starting point int i = 1 j = 1; // Number of steps int N = 2; printf('Probability is %f'findProbability(m n i j N)); return 0; } // This code is contributed by kothavvsaakash.
Java // Java program to find the probability // that we do not cross boundary // of a matrix after N moves. import java.io.*; class GFG { // check if (x y) is valid // matrix coordinate static boolean isSafe(int x int y int m int n) { return (x >= 0 && x < m && y >= 0 && y < n); } // Function to calculate probability // that after N moves from a given // position (x y) in m x n matrix // boundaries of the matrix will // not be crossed. static double findProbability(int m int n int x int y int N) { // boundary crossed if (! isSafe(x y m n)) return 0.0; // N steps taken if (N == 0) return 1.0; // Initialize result double prob = 0.0; // move up prob += findProbability(m n x - 1 y N - 1) * 0.25; // move right prob += findProbability(m n x y + 1 N - 1) * 0.25; // move down prob += findProbability(m n x + 1 y N - 1) * 0.25; // move left prob += findProbability(m n x y - 1 N - 1) * 0.25; return prob; } // Driver code public static void main (String[] args) { // matrix size int m = 5 n = 5; // coordinates of starting point int i = 1 j = 1; // Number of steps int N = 2; System.out.println('Probability is ' + findProbability(m n i j N)); } } // This code is contributed by KRV.
Python3 # Python3 program to find the probability # that we do not cross boundary of a # matrix after N moves. # check if (x y) is valid matrix coordinate def isSafe(x y m n): return (x >= 0 and x < m and y >= 0 and y < n) # Function to calculate probability # that after N moves from a given # position (x y) in m x n matrix # boundaries of the matrix will # not be crossed. def findProbability(m n x y N): # boundary crossed if (not isSafe(x y m n)): return 0.0 # N steps taken if (N == 0): return 1.0 # Initialize result prob = 0.0 # move up prob += findProbability(m n x - 1 y N - 1) * 0.25 # move right prob += findProbability(m n x y + 1 N - 1) * 0.25 # move down prob += findProbability(m n x + 1 y N - 1) * 0.25 # move left prob += findProbability(m n x y - 1 N - 1) * 0.25 return prob # Driver code if __name__ == '__main__': # matrix size m = 5 n = 5 # coordinates of starting po i = 1 j = 1 # Number of steps N = 2 print('Probability is' findProbability(m n i j N)) # This code is contributed by PranchalK
C# // C# program to find the probability // that we do not cross boundary // of a matrix after N moves. using System; class GFG { // check if (x y) is valid // matrix coordinate static bool isSafe(int x int y int m int n) { return (x >= 0 && x < m && y >= 0 && y < n); } // Function to calculate probability // that after N moves from a given // position (x y) in m x n matrix // boundaries of the matrix will // not be crossed. static double findProbability(int m int n int x int y int N) { // boundary crossed if (! isSafe(x y m n)) return 0.0; // N steps taken if (N == 0) return 1.0; // Initialize result double prob = 0.0; // move up prob += findProbability(m n x - 1 y N - 1) * 0.25; // move right prob += findProbability(m n x y + 1 N - 1) * 0.25; // move down prob += findProbability(m n x + 1 y N - 1) * 0.25; // move left prob += findProbability(m n x y - 1 N - 1) * 0.25; return prob; } // Driver code public static void Main () { // matrix size int m = 5 n = 5; // coordinates of starting point int i = 1 j = 1; // Number of steps int N = 2; Console.Write('Probability is ' + findProbability(m n i j N)); } } // This code is contributed by nitin mittal.
PHP // PHP program to find the probability // that we do not cross boundary of a // matrix after N moves. // check if (x y) is valid // matrix coordinate function isSafe($x $y $m $n) { return ($x >= 0 && $x < $m && $y >= 0 && $y < $n); } // Function to calculate probability // that after N moves from a given // position (x y) in m x n matrix // boundaries of the matrix will // not be crossed. function findProbability($m $n $x $y $N) { // boundary crossed if (!isSafe($x $y $m $n)) return 0.0; // N steps taken if ($N == 0) return 1.0; // Initialize result $prob = 0.0; // move up $prob += findProbability($m $n $x - 1 $y $N - 1) * 0.25; // move right $prob += findProbability($m $n $x $y + 1 $N - 1) * 0.25; // move down $prob += findProbability($m $n $x + 1 $y $N - 1) * 0.25; // move left $prob += findProbability($m $n $x $y - 1 $N - 1) * 0.25; return $prob; } // Driver code // matrix size $m = 5; $n = 5; // coordinates of starting point $i = 1; $j = 1; // Number of steps $N = 2; echo 'Probability is ' findProbability($m $n $i $j $N); // This code is contributed by nitin mittal. ?>
JavaScript <script> // JavaScript program to find the probability // that we do not cross boundary of a // matrix after N moves. // check if (x y) is valid matrix coordinate function isSafe(x y m n){ return (x >= 0 && x < m && y >= 0 && y < n); } // Function to calculate probability // that after N moves from a given // position (x y) in m x n matrix // boundaries of the matrix will not be crossed. function findProbability( m n x y N){ // boundary crossed if (!isSafe(x y m n)) return 0.0; // N steps taken if (N == 0) return 1.0; // Initialize result let prob = 0.0; // move up prob += findProbability(m n x - 1 y N - 1) * 0.25; // move right prob += findProbability(m n x y + 1 N - 1) * 0.25; // move down prob += findProbability(m n x + 1 y N - 1) * 0.25; // move left prob += findProbability(m n x y - 1 N - 1) * 0.25; return prob; } // Driver code // matrix size let m = 5 n = 5; // coordinates of starting point let i = 1 j = 1; // Number of steps let N = 2; document.write( 'Probability is ' +findProbability(m n i j N)); </script>
Wyjście
Probability is 0.875