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

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


题目地址

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;
}
相关推荐
肠胃炎9 分钟前
真题246—矩阵计数
java·线性代数·算法·矩阵·深度优先
什码情况10 分钟前
微服务集成测试 -华为OD机试真题(A卷、JavaScript)
javascript·数据结构·算法·华为od·机试
罗西的思考2 小时前
[2W字长文] 探秘Transformer系列之(23)--- 长度外推
人工智能·算法
算AI21 小时前
人工智能+牙科:临床应用中的几个问题
人工智能·算法
hyshhhh1 天前
【算法岗面试题】深度学习中如何防止过拟合?
网络·人工智能·深度学习·神经网络·算法·计算机视觉
杉之1 天前
选择排序笔记
java·算法·排序算法
烂蜻蜓1 天前
C 语言中的递归:概念、应用与实例解析
c语言·数据结构·算法
OYangxf1 天前
图论----拓扑排序
算法·图论
我要昵称干什么1 天前
基于S函数的simulink仿真
人工智能·算法
AndrewHZ1 天前
【图像处理基石】什么是tone mapping?
图像处理·人工智能·算法·计算机视觉·hdr