动态规划前---选----

前言:基本的算法思路还是先看数据范围,接着看能不能用动态规划来做,刚刚好这个题目可以套用前---选---


题目地址

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

#define int long long
int n,m;
const int N = (int)305;
int dp[N][N]; // 前 i 天中选取 j 个糖果的最小费用
int a[N][N];

// 考虑用
signed main(){
    cin >> n >> m;
    for(int i = 1;i<=n;i++){
        vector<int> b; 
        for(int j=1;j<=m;j++){
            int x; cin >> x;
            b.push_back(x);
        }
        sort(b.begin(),b.end());
        for(int j=1;j<=m;j++) a[i][j] = b[j-1];
    }
    for(int i=1;i<=n;i++){
        for(int j=1;j<=n;j++){
            dp[i][j] = 0x3ffffff;
        }
    }
    int now = 0;
    for(int i=1;i<=m;i++){
        now += a[1][i];
        dp[1][i] = now + i*i;
    }
    for(int i=2;i<=n;i++){
        int now = 0;
        for(int j=1;j<=m;j++){
            now += a[i][j];
            // 下面类似背包问题
            for(int k=i-1;k<=n&&(j+k<=n);k++){
                dp[i][j+k] = min({dp[i][j+k],dp[i-1][k]+now+j*j,dp[i-1][j+k]});
            }
        }
    }
    cout << dp[n][n];
    system("pause");
    return 0;
}
相关推荐
2401_8914821725 分钟前
C++模块化编程指南
开发语言·c++·算法
沉鱼.4426 分钟前
树、堆的题目集
算法
暮冬-  Gentle°27 分钟前
自定义类型转换机制
开发语言·c++·算法
2301_8166512238 分钟前
嵌入式C++低功耗设计
开发语言·c++·算法
机器学习之心1 小时前
PSO-LightGBM-ABKDE粒子群算法优化轻量级梯度提升机自适应带宽核密度估计多变量回归区间预测Matlab实现
算法·matlab·回归·abkde·自适应带宽核密度估计·pso-lightgbm·粒子群算法优化轻量级梯度提升机
qq_416018721 小时前
分布式缓存一致性
开发语言·c++·算法
CoovallyAIHub1 小时前
多 Agent 手术推理框架:Agent 辩论+RAG 补上手术知识,零样本超越监督基线 14.6 个百分点
算法·架构·机器人
干啥啥不行,秃头第一名1 小时前
STL容器内部实现剖析
开发语言·c++·算法
Zarek枫煜1 小时前
zig与c3的冒泡排序算法
算法
xiaoye-duck1 小时前
《算法题讲解指南:动态规划算法--简单多状态dp问题》--13.删除并获得点数,14.粉刷房子
c++·算法·动态规划