To the Max(dp)

本文介绍了一种解决二维数组中寻找最大子矩阵和的问题的方法。通过对数组进行预处理,使用动态规划思想,枚举矩阵的长和宽,有效地找到了元素和最大的子矩阵。文章详细解释了算法思路,并提供了完整的C++代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Given a two-dimensional array of positive and negative integers, a sub-rectangle is any contiguous sub-array of size 1*1 or greater located within the whole array. The sum of a rectangle is the sum of all the elements in that rectangle. In this problem the sub-rectangle with the largest sum is referred to as the maximal sub-rectangle.
As an example, the maximal sub-rectangle of the array:

0 -2 -7 0
9 2 -6 2
-4 1 -4 1
-1 8 0 -2
is in the lower left corner:

9 2
-4 1
-1 8
and has a sum of 15.

Input
The input consists of an N * N array of integers. The input begins with a single positive integer N on a line by itself, indicating the size of the square two-dimensional array. This is followed by N^2 integers separated by whitespace (spaces and newlines). These are the N^2 integers of the array, presented in row-major order. That is, all numbers in the first row, left to right, then all numbers in the second row, left to right, etc. N may be as large as 100. The numbers in the array will be in the range [-127,127].

Output
Output the sum of the maximal sub-rectangle.

Sample Input
4
0 -2 -7 0 9 2 -6 2
-4 1 -4 1 -1

8 0 -2
Sample Output
15


题意:在一个n*n的矩阵里找出他元素和最大的子矩阵。 思路:老实说,这个题我一开始想到的是前缀和,然后枚举对角线两个点的坐标求最大值,但是我发现这样好像会t…… 正确的dp姿势应该是用dp数组记录第i行前j个数字的和,然后枚举矩阵的。 长通过上下界确定,宽一步一步考虑,具体看代码。

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<queue>
#include<list>
#include<math.h>
#include<vector>
#include<stack>
#include<string>
#include<set>
#include<map>
#include<numeric>
#include<stdio.h>
#include<functional>
#include<time.h>
#pragma warning(disable:6031)

using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const int maxn = 1111;
const ll mode = 1e9 + 7;
const int inf = 0x3f3f3f3f;
const double pi = 3.14159265358979323846264338327950;
template <class T> inline T min(T a, T b, T c) { return min(min(a, b), c); }
template <class T> inline T max(T a, T b, T c) { return max(max(a, b), c); }
template <class T> inline T min(T a, T b, T c, T d) { return min(min(a, b), min(c, d)); }
template <class T> inline T max(T a, T b, T c, T d) { return max(max(a, b), max(c, d)); }

int dp[150][150];
int main()
{
	int n, x;
	scanf("%d", &n);
	for (int i = 1; i <= n; i++)
		for (int j = 1; j <= n; j++)
		{
			scanf("%d", &x);
			dp[i][j] = dp[i - 1][j] + x;
		}

	int ans = -1000;
	int sum = 0;
	for (int i = 1; i <= n; i++)
		for (int j = i; j <= n; j++)
		{
			sum = 0;
			for (int k = 1; k <= n; k++)
			{
				sum += dp[j][k] - dp[i - 1][k];//加上第k列的i到j的元素的和
				if (sum < 0) sum = 0;//如果小于零,这之前的就不用考虑了
				if (sum > ans) ans = sum;
			}
		}
	printf("%d\n", ans);


	return 0;
}


EDID and DPCD Access Handling by SST-only Mode Branch Devices Upon an EDID read by the DP Source device, a Branch device must reply with the EDID of the downstream DP Sink device. The DP Repeater must update the MAX_LINK_RATE and MAX_LANE_COUNT register (DPCD Addresses 00001h and 00002h, respectively) values to those of the downstream device’s DPRX when the following two conditions are met: • DP Repeater is incapable of changing the link rate and lane count from the upstream link to the downstream link • MAX_LINK_RATE and MAX_LANE_COUNT register values of the downstream device’s DPRX are smaller than those of the DP Repeater’s DPRX In case the DP Repeater is capable of setting the link rate and lane count of the DFP independent of those of the upstream-facing port (UFP), and the downstream device is a DP Sink device, the DP Branch device does not need to update the Receiver Capability field registers (DPCD Addresses 00000h through 000FFh; see Table 2-155). The description of the following two cases explains the rationale behind the above. • Case A – Maximum link bandwidth of the DP Branch device’s DPRX is greater than or equal to that of the downstream DP Sink device’s DPRX The DP Sink device is required to have the maximum link bandwidth that covers all the video timing formats that are declared in its EDID. As the DP Source device selects the video timing format from those listed in the EDID, the maximum link bandwidth of the DP Sink device’s DPRX does not gate the transmission of the video stream. • Case B – Maximum link bandwidth of the DP Branch device’s DPRX is less than or equal to that of the downstream DP Sink device’s DPRX The DP Source device is required to select the video timing format whose stream bandwidth fits within the maximum link bandwidth of the DP Branch device’s DPRX In case the DP Repeater is capable of setting the link rate and lane count of the DFP independent of those of the UFP, but its downstream device is a DP-to-legacy downstream devic
04-01
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值