子矩阵的和(矩阵前缀和)

题目链接:用户登录 - C语言网

在这里可以模拟一下就知道了,

记录每个 (0,0) 到 (i,j)的矩阵和

然后区间子矩阵的和,就减去多余的部分的矩阵和就可以得到了 子矩阵的和

然后 这里最好使用 下标 1 ~ n 到 1 ~ m 存储,这样就可以方便,根据一条规律来使用即可。

初始化函数

cpp 复制代码
// 初始化矩阵前缀和
inline void Init(){
    for(int i = 1;i <= n;++i)
	    for(int j = 1;j <= m;++j)
    	    s[i][j] = s[i - 1][j] + s[i][j - 1] + a[i][j] - s[i - 1][j - 1];
}

获取矩阵和函数

cpp 复制代码
// 根据左上角坐标以及右下角坐标获取矩阵和
inline int getSum(PII p1,PII p2){
	int x1 = p1.x,y1=p1.y;
	int x2 = p2.x,y2=p2.y;
	return s[x2][y2] - s[x2][y1 - 1] - s[x1 - 1][y2] + s[x1 - 1][y1 - 1];
}

题解代码

cpp 复制代码
#include <bits/stdc++.h>
#define int long long
#define endl '\n'
#define x first
#define y second
#define IOS ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
using namespace std;
using PII = pair<int,int>;
const int N = 510;
int a[N][N],s[N][N],n,m,k,ans;
// 初始化矩阵前缀和
inline void Init(){
    for(int i = 1;i <= n;++i)
	    for(int j = 1;j <= m;++j)
    	    s[i][j] = s[i - 1][j] + s[i][j - 1] + a[i][j] - s[i - 1][j - 1];
}

// 根据左上角坐标以及右下角坐标获取矩阵和
inline int getSum(PII p1,PII p2){
	int x1 = p1.x,y1=p1.y;
	int x2 = p2.x,y2=p2.y;
	return s[x2][y2] - s[x2][y1 - 1] - s[x1 - 1][y2] + s[x1 - 1][y1 - 1];
}
signed main(){
	IOS;
	cin >> n;
	m = n;
	for(int i = 1;i <= n;++i)
	    for(int j = 1;j <= m;++j)
			cin >> a[i][j];

// 初始化矩阵前缀和
	Init();
	
// 	循环遍历所有上下坐标,并获取矩阵和
	for(int i = 1;i <= n;++i){
		for(int j = 1;j <= m;++j){
			PII leftUp = PII(i,j);
			for(int x = i;x <= n;++x){
			    for(int y = j;y <= m;++y){
			    	PII rightDown = PII(x,y);
					int sum = getSum(leftUp,rightDown);
					ans = max(sum,ans);
				}
			}
		}
	}

	cout << ans << endl;
	return 0;
}

最后提交

相关推荐
米饭不加菜10 小时前
机器人矩阵运算MATLAB计算
matlab·矩阵·机器人
风筝在晴天搁浅18 小时前
LeetCode 378.有序矩阵中第K小的元素
算法·矩阵
我是大聪明.1 天前
CUDA矩阵乘法优化:共享内存分块与Warp级执行机制深度解析
人工智能·深度学习·线性代数·机器学习·矩阵
做cv的小昊2 天前
【TJU】研究生应用统计学课程笔记(6)——第二章 参数估计(2.4 区间估计)
人工智能·笔记·线性代数·算法·机器学习·数学建模·概率论
EnCi Zheng2 天前
02a-什么是矩阵
线性代数·矩阵
AI科技星2 天前
《全域数学》第一部:数术本源·第二卷《算术原本》之十四附录(二)全域数学体系下三大数论猜想的本源推演与哲学阐释【乖乖数学】
人工智能·线性代数·机器学习·量子计算·agi
有为少年2 天前
从概率估计到“LLM 训练是有损压缩”
人工智能·线性代数·机器学习·计算机视觉·矩阵
风落无尘3 天前
第二章《概率与生存》完整学习资料
人工智能·矩阵·概率论
大江东去浪淘尽千古风流人物3 天前
【UV-SLAM】eLSD/LBD 数据维度 UV-SLAM吸收借鉴
数据库·线性代数·oracle·矩阵·uv·augmented reality
风落无尘3 天前
《智能重生:从垃圾堆到AI工程师》——第三章 矩阵与防线
人工智能·线性代数·矩阵