zoukankan      html  css  js  c++  java
  • 题目:最大加权矩形

    题目描述

    给定一个正整数n( n<=100),然后输入一个N*N矩阵。求矩阵中最大加权矩形,即矩阵的每一个元素都有一权值,权值定义在整数集上。从中找一矩形,矩形大小无限制,是其中包含的所有元素的和最大 。矩阵的每个元素属于[-127,127]
    例:
    0 –2 –7 0 在左下角: 9 2
    9 2 –6 2 -4 1
    -4 1 –4 1 -1 8
    -1 8 0 –2 和为15

    输入格式

    第一行:n,接下来是n行n列的矩阵。

    输出格式

    最大矩形(子矩阵)的和。

    题解:

    用动态规划求最大加权矩形问题。

    代码实现:

    #include<iostream>
    using namespace std;
    
    int f[101][101]={0},n;
    
    int main()
    {
        int i,j,k,l;
        cin>>n;
        for(i=1;i<=n;i++)
        for(j=1;j<=n;j++)
        cin>>f[i][j];
        
        for(i=1;i<=n;i++)
        for(j=1;j<=n;j++)
        f[i][j]+=f[i-1][j];
        
        for(i=1;i<=n;i++)
        for(j=1;j<=n;j++)
        f[i][j]+=f[i][j-1];
        
        int max=-100000;
        for(i=1;i<=n;i++)
        for(j=1;j<=i;j++)
        for(k=1;k<=n;k++)
        for(l=1;l<=k;l++)
        if(f[i][k]-f[j-1][k]-f[i][l-1]+f[j-1][l-1]>max) 
        max=f[i][k]-f[j-1][k]-f[i][l-1]+f[j-1][l-1];
        
        cout<<max<<endl;
        return 0;
        
        }
  • 相关阅读:
    SQLServer之视图简介
    几种快速以伺服静态文件的方法
    Node.js静态文件服务器实战[转]
    mac ssh中文乱码解决
    SSH上传和下载文件
    在web项目中集成pdf.js的默认查看器
    用pip批量更新所有包
    C# 异步锁【转】
    .NET 4并行编程入门之Task的取消[转]
    VIM技巧:选择文本块
  • 原文地址:https://www.cnblogs.com/noip/p/2324181.html
Copyright © 2011-2022 走看看