在 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
广告