Welcome to Subscribe On Youtube
Formatted question description: https://leetcode.ca/all/1701.html
1701. Average Waiting Time (Medium)
There is a restaurant with a single chef. You are given an array customers
, where customers[i] = [arrival_{i}, time_{i}]:
arrival_{i}
is the arrival time of thei^{th}
customer. The arrival times are sorted in nondecreasing order.time_{i}
is the time needed to prepare the order of thei^{th}
customer.
When a customer arrives, he gives the chef his order, and the chef starts preparing it once he is idle. The customer waits till the chef finishes preparing his order. The chef does not prepare food for more than one customer at a time. The chef prepares food for customers in the order they were given in the input.
Return the average waiting time of all customers. Solutions within 10^{5}
from the actual answer are considered accepted.
Example 1:
Input: customers = [[1,2],[2,5],[4,3]] Output: 5.00000 Explanation: 1) The first customer arrives at time 1, the chef takes his order and starts preparing it immediately at time 1, and finishes at time 3, so the waiting time of the first customer is 3  1 = 2. 2) The second customer arrives at time 2, the chef takes his order and starts preparing it at time 3, and finishes at time 8, so the waiting time of the second customer is 8  2 = 6. 3) The third customer arrives at time 4, the chef takes his order and starts preparing it at time 8, and finishes at time 11, so the waiting time of the third customer is 11  4 = 7. So the average waiting time = (2 + 6 + 7) / 3 = 5.
Example 2:
Input: customers = [[5,2],[5,4],[10,3],[20,1]] Output: 3.25000 Explanation: 1) The first customer arrives at time 5, the chef takes his order and starts preparing it immediately at time 5, and finishes at time 7, so the waiting time of the first customer is 7  5 = 2. 2) The second customer arrives at time 5, the chef takes his order and starts preparing it at time 7, and finishes at time 11, so the waiting time of the second customer is 11  5 = 6. 3) The third customer arrives at time 10, the chef takes his order and starts preparing it at time 11, and finishes at time 14, so the waiting time of the third customer is 14  10 = 4. 4) The fourth customer arrives at time 20, the chef takes his order and starts preparing it immediately at time 20, and finishes at time 21, so the waiting time of the fourth customer is 21  20 = 1. So the average waiting time = (2 + 6 + 4 + 1) / 4 = 3.25.
Constraints:
1 <= customers.length <= 10^{5}
1 <= arrival_{i}, time_{i} <= 10^{4}
arrival_{i }<= arrival_{i+1}
Related Topics:
Array
Solution 1.

class Solution { public double averageWaitingTime(int[][] customers) { double total = customers[0][1]; int prev = customers[0][0] + customers[0][1]; int length = customers.length; for (int i = 1; i < length; i++) { int[] customer = customers[i]; int arrival = customer[0], time = customer[1]; if (arrival >= prev) { total += time; prev = arrival + time; } else { int end = prev + time; total += end  arrival; prev += time; } } return total / length; } } ############ class Solution { public double averageWaitingTime(int[][] customers) { double tot = 0; int t = 0; for (var e : customers) { int a = e[0], b = e[1]; t = Math.max(t, a) + b; tot += t  a; } return tot / customers.length; } }

// OJ: https://leetcode.com/problems/averagewaitingtime/ // Time: O(N) // Space: O(1) class Solution { public: double averageWaitingTime(vector<vector<int>>& A) { long total = 0, cur = 0; for (auto &v : A) { long start = v[0], len = v[1]; cur = max(cur, start); total += len + cur  start; cur += len; } return (double)total / A.size(); } };

class Solution: def averageWaitingTime(self, customers: List[List[int]]) > float: tot = t = 0 for a, b in customers: t = max(t, a) + b tot += t  a return tot / len(customers) ############ # 1701. Average Waiting Time # https://leetcode.com/problems/averagewaitingtime/ class Solution: def averageWaitingTime(self, customers: List[List[int]]) > float: current = total = 0 for a,t in customers: current = max(current,a) total += current + t  a current += t return total / len(customers)

func averageWaitingTime(customers [][]int) float64 { tot, t := 0, 0 for _, e := range customers { a, b := e[0], e[1] t = max(t, a) + b tot += t  a } return float64(tot) / float64(len(customers)) } func max(a, b int) int { if a > b { return a } return b }