Saturday, September 28, 2024
Google search engine
HomeData Modelling & AIMinimum time required to complete a work by N persons together

Minimum time required to complete a work by N persons together

Given the no. of working hours of N people individually to complete a certain piece of work. The task is to find the number of hours they will take when all work together. 
Examples: 
 

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

 

Solution: 
 

  • If a person can do a piece of work in ‘n’ days, then in one day, the person will do ‘1/n’ work.
  • Similarly If a person can do a piece of work in ‘m’ days, then in one day, the person will do ‘1/m’ work.
  • So on…. for other persons.

So, total work done by N persons in 1 day is 
 

1/n + 1/m + 1/p…… + 1/z 
Where n, m, p ….., z are the number of days taken by each person respectively.
The result of the above expression will be the part of work done by all person together in 1 day, let’s say a / b
To calculate the time taken to complete the whole work will be b / a.

Consider an example of two persons: 
 

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>


Output: 

1.33333 Hours

 

Time Complexity: O(n), to iterate over the array
Auxiliary Space: O(1)

Note: Here the input array contains hours, it can be days, minutes……so on.
 

Feeling lost in the world of random DSA topics, wasting time without progress? It’s time for a change! Join our DSA course, where we’ll guide you on an exciting journey to master DSA efficiently and on schedule.
Ready to dive in? Explore our Free Demo Content and join our DSA course, trusted by over 100,000 neveropen!

Dominic Rubhabha-Wardslaus
Dominic Rubhabha-Wardslaushttp://wardslaus.com
infosec,malicious & dos attacks generator, boot rom exploit philanthropist , wild hacker , game developer,
RELATED ARTICLES

Most Popular

Recent Comments