在 C++ 中求至少 k 個元素的最大子序列和


在本教程中,我們將討論一個程式,用於查詢至少有 k 個元素的最大和子序列。

為此,我們將提供一個包含整數和一個值 K 的陣列。我們的任務是找到總和最大的子序列,使得所有元素之間的距離至少為 K。

示例

 即時演示

#include <bits/stdc++.h>
using namespace std;
//finding maximum sum subsequence
int maxSum(int arr[], int N, int k) {
   int MS[N];
   MS[N - 1] = arr[N - 1];
   for (int i = N - 2; i >= 0; i--) {
      if (i + k + 1 >= N)
         MS[i] = max(arr[i], MS[i + 1]);
      else
         MS[i] = max(arr[i] + MS[i + k + 1], MS[i + 1]);
   }
   return MS[0];
}
int main() {
   int N = 10, k = 2;
   int arr[] = { 50, 70, 40, 50, 90, 70, 60, 40, 70, 50 };
   cout << maxSum(arr, N, k);
   return 0;
}

輸出

230

更新日期: 2020 年 9 月 9 日

137 次瀏覽

你的 職業生涯精彩開場

完成課程,獲得認證

立即開始
廣告