HDu 2830 Matrix Swapping II(dp)

Problem Description

Given an N * M matrix with each entry equal to 0 or 1. We can find some rectangles in the matrix whose entries are all 1, and we define the maximum area of such rectangle as this matrix’s goodness.

We can swap any two columns any times, and we are to make the goodness of the matrix as large as possible.

Input

There are several test cases in the input. The first line of each test case contains two integers N and M (1 ≤ N,M ≤ 1000). Then N lines follow, each contains M numbers (0 or 1), indicating the N * M matrix

Output

Output one line for each test case, indicating the maximum possible goodness.

Sample Input

3 4
1011
1001
0001
3 4
1010
1001
0001

Sample Output

4
2

Note: Huge Input, scanf() is recommended.

Source

题意:一列一列的移动图,问最大的1组成的面积?

思路:每一行中,对高排序,高就是a【i】,长就是i,我代码中是j,然后就可以求最优解了

</pre><pre name="code" class="cpp">#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;

#define N 1005

int h[N],a[N];
int n,m;

int cmp(int a,int b)
{
    return  a>b;
}

int main()
{
    int i,j;
    char c;

    while(~scanf("%d%d",&n,&m))
    {
        getchar();
        memset(h,0,sizeof(h));

       int ans=0;

       for(i=1;i<=n;i++)
       {
           for(j=1;j<=m;j++)
           {
               scanf("%c",&c);
               if(c=='1')
                 h[j]++;
               else
                 h[j]=0;
           }
           getchar();

           for(j=1;j<=m;j++)
             a[j]=h[j];

           sort(a+1,a+m+1,cmp);  //强调一次,是一列一列的移动

           for(j=1;j<=m;j++)
            ans=max(ans,a[j]*j);
       }
        printf("%d\n",ans);
    }
    return 0;
}
时间: 2024-10-17 11:30:24

HDu 2830 Matrix Swapping II(dp)的相关文章

HDU 2830 Matrix Swapping II (DP,最大全1矩阵)

题意  给你一个n*m矩阵  每列都可以随便交换位置   求最优交换后最大的全1子矩阵 又是HDU 1505 1506的变种  但这个更容易了  因为每列都可以交换位置了   那么这一行中所有比i高的都可以与i相邻了  只需要统计这一行有多少个比i高就行了   可以在算出每一行后  把高度大的放前面去  用num[i]记录排序后的列原来的数  这样就有j列比h[i][num[j]]高了  最后的答案也就是max(j*h[i][num[j]]) #include<cstdio> #include

HDU 2830 Matrix Swapping II (最大完全子矩阵之可移动列)

Matrix Swapping II Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 1210    Accepted Submission(s): 804 Problem Description Given an N * M matrix with each entry equal to 0 or 1. We can find som

hdu 2830 Matrix Swapping II(额,,排序?)

题意: N*M的矩阵,每个格中不是0就是1. 可以任意交换某两列.最后得到一个新矩阵. 问可以得到的最大的子矩形面积是多少(这个子矩形必须全是1). 思路: 先统计,a[i][j]记录从第i行第j列格往上连续的0的个数. 枚举每一行作为答案子矩阵的底, 然后将这一行的a[i][j]从大到小排序,扫一遍计算. 看代码. 代码: int n,m; char temps[1005][1005]; int a[1005][1005]; int ts[1005]; bool cmp(int a,int b

HDU 2830 Matrix Swapping II(最大完全子矩阵之可移动列)

/* 题意: 给你一个矩阵,里面的数字只有0和1两种,其中,列可以任意移动.问如何移动可以使某个子矩阵中元素全部是1,求出这个最大子矩阵的面积. 对每一行进行处理然后再叠加,到每一行用num[i]记下到这一行有多少个1 例如: 1 0 1 1 num[i]的记录就是: 1 0 1 1 1 0 0 1 2 0 0 2 0 0 0 1 0 0 0 3 然后对num[i]从大到小排一下,求出读取到当前行能够得到的最大面积. 也就是最右边放着最多的1,依次类推.那么当前最大的面积就是 MAX(max,n

HDU 2830 Matrix Swapping II

给一个矩阵,依然是求满足条件的最大子矩阵 不过题目中说任意两列可以交换,这是对题目的简化 求出h数组以后直接排序,然后找出(col-j)*h[j]的最大值即可(这里的j是从0开始) 因为排序会影响到h数组下一行的求解,所以将h数组中的元素复制到temp数组中去,再排序 1 //#define LOCAL 2 #include <iostream> 3 #include <cstdio> 4 #include <cstring> 5 #include <algori

HDU 2830 Matrix Swapping II (预处理的线性dp)

Matrix Swapping II Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 1430    Accepted Submission(s): 950 Problem Description Given an N * M matrix with each entry equal to 0 or 1. We can find som

hdu 2830 Matrix Swapping II dp 动态规划

//这题和之前的2870题意相似,不过多了可以任意交换两列的功能 //先开始没看见能交换两列...结果裸的样例都没过,最后想了想//任意交换两列,那我们就可以直接对第i行第j列得到的cnt[i][j] //这一行惊醒排序就可以了,其中cnt[i][j]表示前i行第j列有多少 //个相同的1,进行降序排序得到a[j],那么a[j]*j的最大值就是我 //们所要的答案,因为j前面的肯定是高于j的. //注释部分是我之前的2870的裸的代码,具体可以看我的博客dp46道专题  //哎,继续练吧...

hdu 2830 Matrix Swapping II(hdu1505的加强版)

#include<cstdio> #include<cstring> #include<algorithm> #define N 1005 using namespace std; const int INF=1<<30; char mat[N][N]; int a[N][N]; int L[N],R[N]; int main() { int m,n; memset(a,0,sizeof(0)); while(scanf("%d%d",&

hdu 5623 KK&#39;s Number(dp)

问题描述 我们可爱的KK有一个有趣的数学游戏:这个游戏需要两个人,有N\left(1\leq N\leq 5*{10}^{4} \right)N(1≤N≤5∗10?4??)个数,每次KK都会先拿数.每次可以拿任意多个数,直到NN个数被拿完.每次获得的得分为取的数中的最小值,KK和对手的策略都是尽可能使得自己的得分减去对手的得分更大.在这样的情况下,最终KK的得分减去对手的得分会是多少? 输入描述 第一行一个数T\left( 1\leq T\leq 10\right)T(1≤T≤10),表示数据组