Tiempo mínimo requerido para completar un trabajo por N personas juntas

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>
Producción: 

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

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *