Acwing_795前缀和 【一维前缀和】+Acwing_796子矩阵的和 【二维前缀和】

Acwing_795前缀和 【一维前缀和】

题目:

代码:

cpp 复制代码
#include <bits/stdc++.h>
#define int long long
#define INF 0X3f3f3f3f
#define endl '\n'
using namespace std;
const int N = 100010;
int arr[N];

int n,m;
int l,r;
signed main(){
	
	std::ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	cin>>n>>m;
	int sum[N];
	for(int i = 1; i <= n; i++){
		cin>>arr[i];
		sum[i]= sum[i-1] + arr[i];
	}
	while(m--){
		cin>>l>>r;
		cout<<sum[r]- sum[l-1]<<endl;
	}
	return 0;
}

Acwing_795前缀和 【一维前缀和】

cpp 复制代码
#include <bits/stdc++.h>
#define int long long
#define INF 0X3f3f3f3f
#define endl '\n'
using namespace std;
const int N = 1010;
int arr[N][N];

int n, m, q;
signed main(){
	
	std::ios::sync_with_stdio(false);
	cin.tie(0);
	cout.tie(0);
	int sum[N][N];
	cin>>n>>m>>q;
	for (int i = 1; i <= n; i++){
		for (int j = 1; j <= m; j++){
			cin>>arr[i][j];
			sum[i][j] = sum[i-1][j] +sum[i][j-1]-sum[i-1][j-1]+arr[i][j];			
		}
	}
	while(q--){
		int x1, y1, x2, y2;
		cin>>x1>>y1>>x2>>y2;
		cout<<sum[x2][y2] - sum[x1-1][y2]-sum[x2][y1-1]+sum[x1-1][y1-1]<<endl;
	}
	return 0;
}
相关推荐
夏鹏今天学习了吗1 天前
【LeetCode热题100(73/100)】买卖股票的最佳时机
算法·leetcode·职场和发展
gaosushexiangji1 天前
一项基于粒子图像测速(PIV)速度场反演的压力场重构技术
人工智能·算法
Voyager_41 天前
算法学习记录17——力扣“股票系列题型”
学习·算法·leetcode
雨大王5121 天前
汽车涂装工艺的智能化与绿色化升级:技术、案例与趋势
算法
XFF不秃头1 天前
【力扣刷题笔记-在排序数组中查找元素的第一个和最后一个位置】
c++·笔记·算法·leetcode
yoyo君~1 天前
FAST-LIVO2 深度技术解析
算法·计算机视觉·机器人·无人机
我也要当昏君1 天前
时间复杂度
算法·数学建模
业精于勤的牙1 天前
浅谈:算法中的斐波那契数(六)
人工智能·算法
小孟的CDN1 天前
使用pytorch进行batch_size分批训练,并使用adam+lbfgs算法——波士顿房价预测
pytorch·算法·batch·代码·adam+lbfgs
仰泳的熊猫1 天前
1037 Magic Coupon
数据结构·c++·算法·pat考试