最大子序列和,且不存在連續三個子項
在本教程中,我們將討論如何編寫一個程式,以找到最大子序列和,並且不存在連續三個子項。
為此,我們將提供一系列正整數。我們的任務是找到最大和值,但對於它們的連續正整數,不將其納入和值。
示例
#include <bits/stdc++.h>
using namespace std;
//returning maximum subsequence without involving
//three consecutive numbers
int maxSumWO3Consec(int arr[], int n) {
int sum[n]; if (n >= 1) sum[0] = arr[0];
if (n >= 2) sum[1] = arr[0] + arr[1];
if (n > 2) sum[2] = max(sum[1], max(arr[1] + arr[2], arr[0] + arr[2]));
for (int i = 3; i < n; i++)
sum[i] = max(max(sum[i - 1], sum[i - 2] + arr[i]), arr[i] + arr[i - 1] + sum[i - 3]);
return sum[n - 1];
}
int main() {
int arr[] = { 100, 1000 };
int n = sizeof(arr) / sizeof(arr[0]);
cout << maxSumWO3Consec(arr, n);
return 0;
}輸出
1100
廣告
資料結構
網路
RDBMS
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP