Dado el nro. de horas de trabajo de N personas individualmente para completar un determinado trabajo. La tarea es encontrar la cantidad de horas que tomarán cuando todos trabajen juntos.
Ejemplos:
Input: n = 2, a = 6.0, b = 3.0 Output: 2 Hours Input: n = 3, a = 6.0, b = 3.0, c = 4.0 Output: 1.33333 Hours
Solución:
- Si una persona puede hacer un trabajo en ‘n’ días, entonces en un día, la persona hará ‘1/n’ trabajo.
- De manera similar, si una persona puede hacer un trabajo en ‘m’ días, entonces en un día, la persona hará ‘1/m’ de trabajo.
- Pronto…. para otras personas.
Entonces, el trabajo total realizado por N personas en 1 día es
1/n + 1/m + 1/p…… + 1/z
Donde n, m, p….., z son el número de días que toma cada persona respectivamente.
El resultado de la expresión anterior será la parte del trabajo realizado por todas las personas juntas en 1 día, digamos a/b .
Para el cálculo el tiempo que se tardará en completar toda la obra será b/a .
Considere un ejemplo de dos personas:
Time taken by 1st person to complete a work = 6 hours Time taken by 2nd person to complete the same work = 2 hours Work done by 1st person in 1 hour = 1/6 Work done by 2nd person in 1 hour = 1/2 So, total work done by them in 1 hour is => 1 / 6 + 1/ 2 => (2 + 6) / (2 * 6) => 8 / 12 So, to complete the whole work, the time taken will be 12/8.
C++
// C++ implementation of above approach #include <bits/stdc++.h> using namespace std; // Function to calculate the time float calTime(float arr[], int n) { float work = 0; for (int i = 0; i < n; i++) work += 1 / arr[i]; return 1 / work; } // Driver Code int main() { float arr[] = { 6.0, 3.0, 4.0 }; int n = sizeof(arr) / sizeof(arr[0]); cout << calTime(arr, n) << " Hours"; return 0; }
Java
// Java implementation // of above approach import java.io.*; class GFG { // Function to calculate the time static double calTime(double arr[], int n) { double work = 0; for (int i = 0; i < n; i++) work += 1 / arr[i]; return 1 / work; } // Driver Code public static void main (String[] args) { double arr[] = { 6.0, 3.0, 4.0 }; int n = arr.length; System.out.println(calTime(arr, n) + " Hours"); } } // This code is contributed // by inder_verma.
Python3
# Python3 implementation of # above approach # Function to calculate the time def calTime(arr, n): work = 0 for i in range(n): work += 1 / arr[i] return 1 / work # Driver Code arr = [ 6.0, 3.0, 4.0 ] n = len(arr) print(calTime(arr, n), "Hours") # This code is contributed # by Sanjit_Prasad
C#
// C# implementation // of above approach using System; class GFG { // Function to calculate the time static double calTime(double []arr, int n) { double work = 0; for (int i = 0; i < n; i++) work += 1 / arr[i]; return Math.Round(1 / work, 5); } // Driver Code public static void Main () { double []arr = { 6.0, 3.0, 4.0 }; int n = arr.Length; Console.Write(calTime(arr, n) + " Hours"); } } // This code is contributed by Smitha
PHP
<?php // PHP implementation of above approach // Function to calculate the time function calTime(&$arr, $n) { $work = 0; for ($i = 0; $i < $n; $i++) $work += 1 / $arr[$i]; return 1 / $work; } // Driver Code $arr = array(6.0, 3.0, 4.0); $n = sizeof($arr); echo calTime($arr, $n); echo " Hours"; // This code is contributed // by Shivi_Aggarwal ?>
Javascript
<script> // javascript implementation // of above approach // Function to calculate the time function calTime(arr , n) { var work = 0; for (i = 0; i < n; i++) work += 1 / arr[i]; return 1 / work; } // Driver Code var arr = [ 6.0, 3.0, 4.0 ]; var n = arr.length; document.write(calTime(arr, n).toFixed(5) + " Hours"); // This code is contributed by Rajput-Ji. </script>
1.33333 Hours
Complejidad de tiempo: O(n), para iterar sobre el arreglo
Espacio auxiliar: O(1)
Nota: Aquí la array de entrada contiene horas, pueden ser días, minutos… etc.
Publicación traducida automáticamente
Artículo escrito por Naman_Garg y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA