zoukankan      html  css  js  c++  java
  • HDU-1081-To The Max

    求最大连续子矩阵和问题

    可以转化为求最大连续子序列问题

    map[i][j]=map[0][j]+map[1][j]+...+map[i][j]

    即将第 j 列前 i 行的值压缩到map[i][j]

    求第 x 行到第 y 行之间最大连续矩阵和,就将 x~y 行同列元素当成一个元素处理

    这样就将 x~y 行压缩成了一行。再求最大连续子序列

    若有4行

    分别将第 1,  1和2,  1和2和3,  1和2和3和4,  2和3,  2和3和4,  3和4,  4 行压缩为一行 

    代码如下:

    #include<stdio.h>
    int map[105][105];
    int main()
    {
        int n,i,j,k;
        while(scanf("%d",&n)!=EOF)
        {
            int t;
            for(i=1; i<=n; i++)
                for(j=1; j<=n; j++)  //读数据时就压缩
                {
                    scanf("%d",&t);
                    map[i][j]=map[i-1][j]+t;
                }
            int max=0;
            for(i=1; i<=n; i++)    //三个循环求所有压缩情况中的最大值
            {
                for(j=i; j<=n; j++)
                {
                    int s=0;
                    for(k=1; k<=n; k++)    //k 控制列
                    {
                        s+=map[j][k]-map[i-1][k];  // i~j 行压缩为一行,求最大连续子序列
                        if(s<0) s=0;                //值为负,舍弃
                        if(s>max) max=s;
                    }
                }
            }
            printf("%d
    ",max);
        }
        return 0;
    }
    View Code
  • 相关阅读:
    0918作业-----所有数值未做合法性检测
    尝试安装和配置JDK,并给出安装、配置JDK的步骤
    java为什么可以跨平台执行
    字符集
    java 入门及简介
    时间轴特效
    javascript简介
    javascript while循环
    Javascript for循环
    函数豹子问题
  • 原文地址:https://www.cnblogs.com/Houheshuai/p/3698838.html
Copyright © 2011-2022 走看看