สมมติว่าเรามีอาร์เรย์ที่เก็บตัวเลขบวกและลบ อาร์เรย์เป็นตัวแทนของจุดตรวจจากปลายด้านหนึ่งไปยังอีกด้านหนึ่งของถนน ค่าบวกและค่าลบแสดงถึงพลังงานที่จุดตรวจ ค่าบวกสามารถเพิ่มพลังงานได้ และค่าลบจะทำให้พลังงานลดลง เราต้องหาระดับพลังงานเริ่มต้นในการข้ามถนน เพื่อไม่ให้ระดับพลังงานกลายเป็น 0 หรือน้อยกว่า 0
สมมติว่าเรามีอาร์เรย์ A ={4, -6, 2, 3} ให้พลังงานตั้งต้นเป็น 0 ดังนั้นเมื่อถึงด่านแรก พลังงานจะเป็น 4 ทีนี้ ไปด่านที่สอง พลังงานจะเป็น 4 + (-6) =-2 พลังงานจึงน้อยกว่า 0 เราจึงต้องเริ่มการเดินทางด้วย 3 ดังนั้นหลังจากครั้งแรกจะเป็น 3 + 4 =7 และหลังจากผ่านด่านที่สองจะเป็น 7 + (-6) =1พี>
อัลกอริทึม
minInitEnergy(arr, n): begin initEnergy := 0 currEnergy := 0 flag := false for i in range 0 to n, do currEnergy := currEnergy + arr[i] if currEnergy <= 0, then initEnergy := initEnergy + absolute value of currEnergy + 1 currEnergy := 1 flag := true end if done if flag is false, return 1, otherwise return initEnergy end
ตัวอย่าง
#include <iostream> #include <cmath> using namespace std; int minInitEnergy(int arr[], int n){ int initEnergy = 0; int currEnergy = 0; bool flag = false; for (int i = 0; i<n; i++){ currEnergy = currEnergy + arr[i]; if (currEnergy <= 0){ initEnergy = initEnergy + abs(currEnergy) + 1; currEnergy = 1; flag = true; } } if (flag == false) return 1; else return initEnergy; } int main() { int A[] = {4, -6, 2, 3}; int n = sizeof(A)/sizeof(A[0]); cout << "Minimum Energy: " << minInitEnergy(A, n); }
ผลลัพธ์
Minimum Energy: 3