ในปัญหานี้ เราได้รับอาร์เรย์ arr[] งานของเราคือสร้างโปรแกรมเพื่อค้นหาผลรวมสูงสุดเพื่อไม่ให้มีองค์ประกอบสองรายการอยู่ติดกันใน C++
คำอธิบายปัญหา
เราจำเป็นต้องหาผลรวมสูงสุดของลำดับจากอาร์เรย์นั้นเพื่อไม่ให้มีตัวเลข 2 จากลำดับผลรวมอยู่ติดกันในอาร์เรย์
มาดูตัวอย่างเพื่อทำความเข้าใจปัญหากัน
อินพุต
arr[] = {5, 1, 3, 7, 9, 2, 5}
ผลลัพธ์
22
คำอธิบาย
Taking sum sequence from index 0 with alternate elements : 5 + 3 + 9 + 5 = 22 Taking sum sequence from index 1 with alternate elements : 1 + 7 + 2 = 10
แนวทางการแก้ปัญหา
ในเซตที่แล้ว เราได้เห็นแนวทางหนึ่งในการแก้ปัญหานี้แล้ว ที่นี่ เราจะเรียนรู้เกี่ยวกับวิธีการเขียนโปรแกรมแบบไดนามิกเพื่อแก้ปัญหา
ในการแก้ปัญหาโดยใช้ Dynamic Approach เราจำเป็นต้องสร้างอาร์เรย์ DP[] ที่จัดเก็บผลรวมสูงสุดจนถึงดัชนีปัจจุบัน แล้วหาดัชนีผลรวมโดยใช้อาร์เรย์ไดนามิกนี้
DP max ปัจจุบันคือค่าสูงสุดของ dp[i+2]+ arr[i] และ dp[i+1]
ตัวอย่าง
โปรแกรมเพื่อแสดงการทำงานของโซลูชันของเรา
#include <iostream> using namespace std; int DP[100]; bool currState[100]; int maxVal(int a, int b){ if(a > b) return a; return b; } int calcMaxSumWOAdj(int arr[], int i, int n){ if (i >= n) return 0; if (currState[i]) return DP[i]; currState[i] = 1; DP[i] = maxVal(calcMaxSumWOAdj(arr, i + 1, n), arr[i] + calcMaxSumWOAdj(arr, i + 2, n)); return DP[i]; } int main(){ int arr[] = { 5, 1, 3, 7, 9, 2, 5 }; int n = sizeof(arr) / sizeof(int); cout<<"The maximum sum such that no two elements are adjacent is "<<calcMaxSumWOAdj(arr, 0, n); return 0; }
ผลลัพธ์
The maximum sum such that no two elements are adjacent is 22