สมมติว่าเรามีอาร์เรย์ของจำนวนเต็ม เราต้องหาผลรวมขององค์ประกอบที่มีอยู่จากดัชนี i ถึง j สองสิ่งที่เราต้องจำไว้คืออาร์เรย์จะไม่เปลี่ยนรูป ดังนั้นองค์ประกอบจะไม่ถูกแก้ไข และจะมีข้อความค้นหาดังกล่าวหลายรายการ ดังนั้นเราจึงต้องคำนึงถึงเวลาดำเนินการสำหรับข้อความค้นหาจำนวนมาก สมมติว่าอาร์เรย์เป็นเหมือน A =[5, 8, 3, 6, 1, 2, 5] ดังนั้นหากการสืบค้นคือ (A, 0, 3) ก็จะเป็น 5 + 8 + 3 + 6 =22
เพื่อแก้ปัญหานี้ เราจะทำตามขั้นตอนเหล่านี้ -
- รับหนึ่งอาร์เรย์ B. B[i] จะเก็บผลรวมขององค์ประกอบตั้งแต่ 0 ถึง i
- สำหรับแบบสอบถามดำเนินการ B[j] – B[i – 1]
ให้เราดูการใช้งานต่อไปนี้เพื่อความเข้าใจที่ดีขึ้น -
ตัวอย่าง
#include <bits/stdc++.h> using namespace std; class NumArray { public: vector <int> pre; NumArray(vector<int>& nums) { pre.clear(); int n = nums.size(); pre.resize(n); for(int i = 0; i < n; i++){ if(i == 0)pre[0] = nums[0]; else pre[i] = pre[i - 1] + nums[i]; } } int sumRange(int i, int j) { if(i == 0)return pre[j]; return pre[j] - pre[i - 1]; } }; main(){ vector<int> v = {5,8,3,6,1,2,5}; NumArray na(v); cout<<na.sumRange(0,2)<<endl; cout<<na.sumRange(2,5)<<endl; cout<<na.sumRange(0,5)<<endl; }
อินพุต
Initialize it with [5,8,3,6,1,2,5] Call sumRange(0,2) sumRange(2,5) sumRange(0,5)
ผลลัพธ์
16 12 25