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

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


题目地址

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;
}
相关推荐
孤飞5 小时前
zero2Agent:面向大厂面试的 Agent 工程教程,从概念到生产的完整学习路线
算法
技术专家6 小时前
Stable Diffusion系列的详细讨论 / Detailed Discussion of the Stable Diffusion Series
人工智能·python·算法·推荐算法·1024程序员节
csdn_aspnet7 小时前
C# (QuickSort using Random Pivoting)使用随机枢轴的快速排序
数据结构·算法·c#·排序算法
鹿角片ljp7 小时前
最长回文子串(LeetCode 5)详解
算法·leetcode·职场和发展
paeamecium9 小时前
【PAT甲级真题】- Cars on Campus (30)
数据结构·c++·算法·pat考试·pat
chh5639 小时前
C++--模版初阶
c语言·开发语言·c++·学习·算法
RTC老炮10 小时前
带宽估计算法(gcc++)架构设计及优化
网络·算法·webrtc
dsyyyyy110110 小时前
计数孤岛(DFS和BFS解决)
算法·深度优先·宽度优先
会编程的土豆11 小时前
01背包与完全背包详解
开发语言·数据结构·c++·算法
汀、人工智能11 小时前
[特殊字符] 第86课:最大正方形
数据结构·算法·数据库架构·图论·bfs·最大正方形