前缀数组的介绍和使用

我们先来实现一个二维数组的前缀:

int main()

{

int n, m, q;

cin>>n >>m >> q;

vector<vector<int>> arr(n + 1, vector<int>(m + 1));

for (int i = 1; i <= n; i++) {

for (int j = 1; j <= m; j++) {

cin >> arrij;

}

}

vector<vector<long long>> dp(n + 1, vector<long long>(m + 1));

for (int i = 1; i <= n; i++) {

for (int j = 1; j <= m; j++) {

dpij = dpi - 1j + dpij - 1 + arrij - dpi - 1j - 1;

int x1 = 0, y1 = 0, x2 = 0, y2 = 0;

while (q > 0) {

q--;

cin >> x1 >> y1 >> x2 >> y2;

cout << dpx2y2 - dpx1 - 1y2 - dpx2y1 - 1 + dpx1 - 1y1 - 1 << endl;

}

}

}

return 0;

}

class Solution {

public:

vector<int> productExceptSelf(vector<int>& nums) {

int n=nums.size();

vector<int> f(n),g(n);

f0=1;

gn-1=1;

for(int i=1;i<n;i++){

fi=fi-1*numsi-1;

}

for(int i=n-2;i>=0;i--){

gi=gi+1*numsi+1;

}

vector<int> ret(n);

for(int i=0;i<n;i++){

reti=fi*gi;

}

return ret;

}

};

class Solution {

public:

int subarraySum(vector<int>& nums, int k) {

unordered_map<int,int> hash;

hash0=1;

int sum=0,ret=0;

for(auto e:nums){

sum+=e;

if(hash.count(sum-k)) ret+=hashsum-k;

hashsum++;

}

return ret;

}

};

class Solution {

public:

int pivotIndex(vector<int>& nums) {

int n=nums.size();

vector<int> f(n),g(n);

for(int i=1;i<n;i++){

fi=fi-1+numsi-1;

}

for(int j=n-2;j>=0;j--){

gj=gj+1+numsj+1;

}

for(int i=0;i<n;i++){

if(fi==gi){

return i;

}

}

return -1;

}

};

class Solution {

public:

int findMaxLength(vector<int>& nums) {

int n=nums.size();

unordered_map<int,int> hash;

hash0=-1;

int sum=0,ret=0;

for(int i=0;i<n;i++){

sum+=numsi==0?-1:1;

if(hash.count(sum)) ret=max(ret,i-hashsum);

else hashsum=i;

}

return ret;

}

};

class Solution {

public:

vector<vector<int>> matrixBlockSum(vector<vector<int>>& mat, int k) {

int m=mat.size(),n=mat0.size();

vector<vector<int>> dp(m+1,vector<int>(n+1));

for(int i=1;i<=m;i++){

for(int j=1;j<=n;j++){

dpij=dpi-1j+dpij-1+mati-1j-1-dpi-1j-1;

}

}

vector<vector<int>> ret(m,vector<int>(n));

for(int i=0;i<m;i++){

for(int j=0;j<n;j++){

int x1=max(0,i-k)+1,y1=max(0,j-k)+1;

int x2=min(m-1,i+k)+1,y2=min(n-1,j+k)+1;

retij=dpx2y2-dpx1-1y2-dpx2y1-1+dpx1-1y1-1;

}

}

return ret;

}

};

相关推荐
雪度娃娃19 分钟前
ASIO异步通信——多线程模型
开发语言·网络·c++·php
嵌入式老牛23 分钟前
液晶段码(米/日字格)识别—倾斜校正
opencv·算法·仿射变换
luj_176825 分钟前
残熵算法:风险缓冲与效率优化的融合
c语言·开发语言·网络·经验分享·算法
oddsand11 小时前
pgvector 三大相似度算法
人工智能·算法·机器学习
运筹vivo@1 小时前
LeetCode 2574. 左右元素和的差值
算法·leetcode·职场和发展·每日一题
计算机安禾1 小时前
【数据库系统原理】第4篇:关系数据结构的形式化定义:域、笛卡尔积与关系模式
数据结构·数据库·算法
手写码匠2 小时前
手写 DeepSeek 推理引擎优化:从 FP16 到 INT4 的量化加速实战
人工智能·深度学习·算法·aigc
GuWenyue2 小时前
LeetCode 76 最小覆盖子串|JS 滑动窗口标准解法
前端·算法·面试
一只齐刘海的猫2 小时前
【Leetcode】移动零
算法·leetcode·职场和发展
指针战神2 小时前
synchronized简易版Redis版跳表实现(注释干货)
数据结构