Codeforces Round #655 (Div. 2)E(矩阵范围dp)

题:https://codeforces.com/contest/1372/problem/E

题意:给定矩形,每行有k和区间划分,每个区间只能有1个1,问设值后每列和的平方相加最大是多少

分析:考虑dp[i][j]表示第 i 列到第 j 列之间的最大值,考虑枚举区间,枚举区间的同时枚举区间中的每一列,贪心地,某一列的1越多,对答案贡献越大,所以把能给的1全给当前枚举的这一列,以次dp。

#include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
using namespace std;
typedef long long ll;
const int M=1e2+2;
ll dp[M][M],L[M][M],R[M][M];
int main(){
    ios::sync_with_stdio(false);
    cin.tie(0);
    int n,m;
    cin>>n>>m;
    for(int i=1;i<=n;i++){
        int q;
        cin>>q;
        while(q--){
            int l,r;
            cin>>l>>r;
            for(int j=l;j<=r;j++){
                L[i][j]=l;
                R[i][j]=r;
            }
        }
    }
    for(int l=m;l>=1;l--)
        for(int r=l;r<=m;r++){
            for(int k=l;k<=r;k++){
                int countt=0;
                for(int i=1;i<=n;i++)
                    if(l<=L[i][k]&&R[i][k]<=r){
                        countt++;
                    }
                dp[l][r]=max(dp[l][r],dp[k+1][r]+dp[l][k-1]+countt*countt);
            }
        }
    cout<<dp[1][m]<<endl;
    return 0;
}
View Code
原文地址:https://www.cnblogs.com/starve/p/13355384.html