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

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


题目地址

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;
}
相关推荐
redcocal1 小时前
地平线内推码 kbrfck
c++·嵌入式硬件·mcu·算法·fpga开发·求职招聘
西农小陈3 小时前
python-字符排列问题
数据结构·python·算法
TechQuester3 小时前
OpenAI 刚刚推出 o1 大模型!!突破LLM极限
人工智能·python·gpt·算法·chatgpt
西农小陈3 小时前
python-简单的数据结构
数据结构·python·算法
_Chocolate3 小时前
十大排序(一):冒泡排序
c语言·数据结构·算法
running thunderbolt4 小时前
C++:类和对象全解
c语言·开发语言·c++·算法
小陈的进阶之路4 小时前
c++刷题
开发语言·c++·算法
model20055 小时前
sahi目标检测java实现
java·算法·目标检测
源代码•宸5 小时前
Leetcode—322. 零钱兑换【中等】(memset(dp,0x3f, sizeof(dp))
c++·算法·leetcode·职场和发展·dp
机械心5 小时前
最优化理论与自动驾驶(一):概述
人工智能·算法·自动驾驶