สมมติว่าเรามีอาร์เรย์ A ที่มีองค์ประกอบ n และมีค่าอื่น t ในวันที่ Amal ใช้เวลา A[i] วินาทีในการทำงาน ในเวลาว่างเขาอ่านหนังสือ หนังสือทั้งเล่มจะใช้เวลา t วินาทีจึงจะเสร็จสมบูรณ์ เราต้องหาว่าเขาจะอ่านหนังสือให้จบกี่วัน
ดังนั้น หากอินพุตเป็น A =[86400, 86398]; t =2 ผลลัพธ์จะเป็น 2 เพราะวันหนึ่งมี 86400 วินาที และวันแรกจะถูกบล็อกโดยสิ้นเชิง ในวันที่สอง เขาจะได้รับ 2 วินาทีในการทำหนังสือให้เสร็จ
ขั้นตอน
เพื่อแก้ปัญหานี้ เราจะทำตามขั้นตอนเหล่านี้ -
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)
ตัวอย่าง
ให้เราดูการใช้งานต่อไปนี้เพื่อความเข้าใจที่ดีขึ้น -
#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;
} อินพุต
{ 86400, 86398 }, 2 ผลลัพธ์
2