Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> C++

ผลรวมสูงสุดที่ไม่มีสององค์ประกอบอยู่ติดกัน - ตั้งค่า 2 ใน C ++


ในปัญหานี้ เราได้รับอาร์เรย์ 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