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

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


题目地址

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;
}
相关推荐
地平线开发者12 小时前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮12 小时前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者13 小时前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考13 小时前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx16 小时前
CART决策树基本原理
算法·机器学习
Wect16 小时前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
颜酱17 小时前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法
Gorway1 天前
解析残差网络 (ResNet)
算法
拖拉斯旋风1 天前
LeetCode 经典算法题解析:优先队列与广度优先搜索的巧妙应用
算法
Wect1 天前
LeetCode 207. 课程表:两种解法(BFS+DFS)详细解析
前端·算法·typescript