当前位置:首页 > 算法 > 正文内容

【贪心】最大子矩阵

亿万年的星光5年前 (2021-02-19)算法20640

【题目描述】

已知矩阵的大小定义为矩阵中所有元素的和。给定一个矩阵,你的任务是找到最大的非空(大小至少是1X1)子矩阵。

比如,如下4 x 4的矩阵

0    -2    -7    0

9    2    -6    2

-4    1    4    1

-1    8    0    -2

的最大子矩阵是

9    2

-4    1

-1    8

这个子矩阵的大小是15。

【输入描述】

输入是一个N x NN(0<N<=100)。再后面的若干行中,依次(首先从左到右给出第一行的N个整数,再从左到右给出第二行的N个整数...)给出矩阵中的N2个整数,整数之间由空白字符分隔(空格或者空行)。已知矩阵中整数的范围都在[-127,127]。


【输出描述】

最大子矩阵的大小

【样例输入】

4
 0 -2 -7  0
 9  2 -6  2
-4  1 -4  1
-1  8  0 -2

【样例输出】

15

【题目分析与思路

  1. 这道题的目的是找到最大非空子矩阵,最小的那个是1x1的矩阵。

  2. 可以用贪心,可以用动态规划

  3. 二维数组可以看出一维数组



【参考代码1】

#include<iostream>
#include<cstring>
using namespace std;
 
int search(int n,int a[])//求一维数组连续子列和
{
	int sum=0,max=0;
	for(int i=0;i<n;i++)
	{
		if(sum>0)
			sum+=a[i];  //大于0才累加 
		else
			sum=a[i];  //小于0保持 
		if(sum>max)
			max=sum;
	}
	return max;
}
 
int main()
{
	int n,a[100][100],temp[100];
	int maxc=0,max=0;
	cin>>n;
	for(int i=0;i<n;i++)
		for(int j=0;j<n;j++)
			cin>>a[i][j];
	for(int i=0;i<n;i++)//记录矩阵开始的行号
	{
		memset(temp,0,sizeof(temp));
		for(int j=i;j<n;j++)//记录矩阵结束的行号
		{
			for(int k=0;k<n;k++)
				temp[k]+=a[j][k]; 
			maxc=search(n,temp);    //每次传入一个数组 
			if(maxc>max)
				max=maxc; 
		}
	}
	cout<<max<<endl;
	return 0;
}






    扫描二维码推送至手机访问。

    版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

    标签: 贪心
    分享给朋友:

    相关文章

    【算法】单调栈

    一、单调栈单调栈(Monotonic Stack)是一种特殊的栈结构,其核心思想是维护栈内元素的单调性(单调递增或单调递减)。单调栈通常用于解决与元素大小关系相关的问题,例如:找到数组中每个元素的下一...

    【贪心】----排队打水

    【贪心】----排队打水

    一、基础版排队打水【题目描述】学校里有一个水房,水房里一共装有m 个龙头可供同学们打开水,每个龙头每秒钟的供水量相等,均为1。现在有n 名同学准备接水,他们的初始接水顺序已经确定。...

    【贪心】 导弹拦截

    【贪心】 导弹拦截

    【题目描述】某国为了防御敌国的导弹袭击,开发出一种导弹拦截系统,但是这种拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度。某天,雷达捕捉到敌国的导弹来...

    【算法】归并排序

    【算法】归并排序

    一、基本思想归并排序的核心思想是将两个已经有序的子序列合并成一个有序序列。整个过程分为两个主要步骤: 1.分解:将待排序的序列不断二分,直到每个子序列只包含一个元素(此时自然有序) ...

    【算法】高精度(2)

    五、高精度处理进位与借位    其实也很简单,我们再来模拟一下,1439+887的时候,首先我们最低位相加,得到16,那么答案最低位就是6,再进个1,然后两数的十位相加,...

    【算法】动态规划(一)

    1.基本概念在现实生活中,有一类活动的过程,由于它的特殊性,可将过程分成若干个互相联系的阶段,在它的每一阶段都需要作出决策,从而使整个过程达到最好的活动效果。因此各个阶段决策的选取不能任意确定,它依赖...