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;
}
相关推荐
学无止境\n3 分钟前
[C语言]指针和数组
c语言·数据结构·算法
黄俊懿7 分钟前
【深入理解SpringCloud微服务】手写实现各种限流算法——固定时间窗、滑动时间窗、令牌桶算法、漏桶算法
java·后端·算法·spring cloud·微服务·架构
新缸中之脑7 分钟前
Llama 3.2 安卓手机安装教程
前端·人工智能·算法
夜雨翦春韭27 分钟前
【代码随想录Day29】贪心算法Part03
java·数据结构·算法·leetcode·贪心算法
Curry_Math44 分钟前
Acwing 区间DP & 计数类DP
算法
Tisfy1 小时前
LeetCode 1928.规定时间内到达终点的最小花费:动态规划
算法·leetcode·动态规划·
ん贤1 小时前
贪心算法.
算法·贪心算法
cndes1 小时前
大数据算法的思维
大数据·算法·支持向量机
睡不着还睡不醒3 小时前
【数据结构强化】应用题打卡
算法
sp_fyf_20243 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-05
人工智能·深度学习·神经网络·算法·机器学习·语言模型·自然语言处理