Giả sử chúng ta có một mảng A với n phần tử và có một giá trị khác là t. Vào ngày thứ i, Amal dành A [i] giây để làm việc. Trong thời gian rảnh anh ấy đọc sách. Toàn bộ cuốn sách sẽ mất t giây để hoàn thành. Chúng ta phải tìm xem anh ta sẽ cần bao nhiêu ngày để đọc hết cuốn sách.
Vì vậy, nếu đầu vào là A =[86400, 86398]; t =2, thì đầu ra sẽ là 2, vì một ngày có 86400 giây và ngày đầu tiên bị chặn hoàn toàn. Vào ngày thứ hai, anh ấy sẽ có 2 giây để hoàn thành cuốn sách.
Các bước
Để giải quyết vấn đề này, chúng tôi sẽ làm theo các bước sau -
cnt := 1 n := size of A for initialize i := 0, when i < n, update (increase i by 1), do: x := A[i] t := t - 86400 - x if t <= 0, then: return cnt (increase cnt by 1)
Ví dụ
Hãy cùng chúng tôi xem cách triển khai sau để hiểu rõ hơn -
#include <bits/stdc++.h> using namespace std; int solve(vector<int> A, int t){ int cnt = 1; int n = A.size(); for (int i = 0; i < n; i++){ int x = A[i]; t -= 86400 - x; if (t <= 0){ return cnt; } ++cnt; } } int main(){ vector<int> A = { 86400, 86398 }; int t = 2; cout << solve(A, t) << endl; }
Đầu vào
{ 86400, 86398 }, 2
Đầu ra
2