ในบทช่วยสอนนี้ เราจะพูดถึงโปรแกรมเพื่อค้นหาผลรวมของอาร์เรย์ย่อยสูงสุดในอาร์เรย์ที่สร้างขึ้นหลังจากการต่อข้อมูลซ้ำๆ
สำหรับสิ่งนี้ เราจะได้รับอาร์เรย์และจำนวนเต็ม K หน้าที่ของเราคือค้นหาอาร์เรย์ย่อยที่มีองค์ประกอบสูงสุดเมื่ออาร์เรย์ที่ระบุซ้ำ K ครั้ง
ตัวอย่าง
#include<bits/stdc++.h> using namespace std; //returning sum of maximum subarray int maxSubArraySumRepeated(int a[], int n, int k) { int max_so_far = INT_MIN, max_ending_here = 0; for (int i = 0; i < n*k; i++) { max_ending_here = max_ending_here + a[i%n]; if (max_so_far < max_ending_here) max_so_far = max_ending_here; if (max_ending_here < 0) max_ending_here = 0; } return max_so_far; } int main() { int a[] = {10, 20, -30, -1}; int n = sizeof(a)/sizeof(a[0]); int k = 3; cout << "Maximum contiguous sum is " << maxSubArraySumRepeated(a, n, k); return 0; }
ผลลัพธ์
Maximum contiguous sum is 30