第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定

??途W(wǎng)12533,合唱團題解:乘積最大化問題的動態(tài)規(guī)劃解法

標簽:
C++

https://img1.sycdn.imooc.com/0af34368087c5a5909670695.jpg

一、问题分析与算法设计

这是一个典型的动态规划问题,需要考虑正负值对乘积的影响。我们需要维护两个DP数组:一个记录最大值,一个记录最小值(因为负负得正)。

二、C++代码实现

#include <iostream>
#include <vector>
#include <climits>
using namespace std;
long long maxProduct(int n, vector<int>& ability, int k, int d) {
// dp_max[i][j]表示选j个人,最后一个人是i时的最大乘积
// dp_min[i][j]表示选j个人,最后一个人是i时的最小乘积
vector<vector<long long>> dp_max(n+1, vector<long long>(k+1, LLONG_MIN));
vector<vector<long long>> dp_min(n+1, vector<long long>(k+1, LLONG_MAX));
// 初始化:选1个人时就是自己的能力值
for(int i = 1; i <= n; i++) {
dp_max[i][1] = ability[i-1];
dp_min[i][1] = ability[i-1];
}
for(int j = 2; j <= k; j++) { // 选j个人
for(int i = j; i <= n; i++) { // 当前选第i个人
// 前一个人只能在[i-d, i-1]范围内
int start = max(j-1, i-d); // 至少需要j-1个人
for(int l = start; l < i; l++) {
// 考虑三种情况:正×正,负×负,正×负
dp_max[i][j] = max(dp_max[i][j],
max(dp_max[l][j-1] * ability[i-1],
dp_min[l][j-1] * ability[i-1]));
dp_min[i][j] = min(dp_min[i][j],
min(dp_max[l][j-1] * ability[i-1],
dp_min[l][j-1] * ability[i-1]));
}
}
}
// 找出选k个人时的最大乘积
long long result = LLONG_MIN;
for(int i = k; i <= n; i++) {
result = max(result, dp_max[i][k]);
}
return result;
}
int main() {
int n, k, d;
cin >> n;
vector<int> ability(n);
for(int i = 0; i < n; i++) cin >> ability[i];
cin >> k >> d;
cout << maxProduct(n, ability, k, d) << endl;
return 0;
}


三、算法解析

  1. 数据结构设计

  • 使用两个二维数组分别存储最大值和最小值

  • 考虑正负值对乘积的影响

关键处理逻辑

  • 三重循环处理状态转移

  • 每次考虑前d个位置的可能情况

  • 同时维护最大值和最小值

复杂度分析

  • 时间复杂度:O(nkd)

  • 空间复杂度:O(n*k)

来源:牛客网12533,合唱团题解:乘积最大化问题的动态规划解法


點擊查看更多內(nèi)容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優(yōu)質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優(yōu)惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網(wǎng)微信公眾號

舉報

0/150
提交
取消