当前位置: 首页 > wzjs >正文

seo网站推广什么意思网站建设厘金手指下拉12

seo网站推广什么意思,网站建设厘金手指下拉12,个人申请网站,设计网站猪八戒一维差分 问题描述 给定一个长度为 nn 的序列 aa。 再给定 mm 组操作,每次操作给定 33 个正整数 l,r,dl,r,d,表示对 al∼ral∼r​ 中的所有数增加 dd。 最终输出操作结束后的序列 aa。 Update:由于评测机过快,n,mn,m 于 2024…

一维差分

问题描述

给定一个长度为 nn 的序列 aa

再给定 mm 组操作,每次操作给定 33 个正整数 l,r,dl,r,d,表示对 al∼ralr​ 中的所有数增加 dd

最终输出操作结束后的序列 aa

Update:由于评测机过快,n,mn,m 于 2024-12-09 从 105105 加强至 2×1052×105,杜绝暴力通过本题。 

输入格式

第一行输入两个正整数 n,mn,m。(1≤n,m≤2×1051≤n,m≤2×105)

第二行输入 nn 个正整数 aiai​。(1≤i≤n,1≤ai≤1041≤in,1≤ai​≤104)。

接下来 mm 行,每行输入 33 个正整数 l,r,dl,r,d。(1≤l≤r≤n,−104≤d≤1041≤lrn,−104≤d≤104)。

输出格式

输出 nn 个整数,表示操作结束后的序列 aa

样例输入

6 3
1 2 2 1 2 1
1 3 1
3 5 1
1 6 1

样例输出

3 4 5 3 4 2
#include <bits/stdc++.h>
using namespace std;int main(){int n,q;cin >> n >> q;vector<int> a(n+1,0);for(int i=1;i<=n;i++){cin >> a[i];}vector<int> diff(n+1,0);while(q--){int x1,y1,d;cin >> x1 >> y1 >> d;diff[x1] += d;if(y1+1 <= n){diff[y1+1] -= d;}}for(int i=1;i<=n;i++){diff[i] += diff[i-1];a[i] += diff[i];}for(int i=1;i<=n;i++){cout << a[i] << " ";}
}

二维差分

问题描述

给定一个 n×mn×m 大小的矩阵 AA。

给定 qq 组操作,每次操作为给定 55 个正整数 x1,y1,x2,y2,dx1​,y1​,x2​,y2​,d,Ax1,y1Ax1​,y1​​ 是子矩阵左上角端点,Ax2,y2Ax2​,y2​​ 是子矩阵右下角端点,你需要给其中每个元素都增加 dd。

输出操作结束后的矩阵 AA。

输入格式

第一行输入 33 个正整数 n,m,qn,m,q。(1≤n,m≤103,1≤q≤1051≤n,m≤103,1≤q≤105)

接下来 nn 行每行输入 mm 个整数,表示 Ai,jAi,j​。(−103≤Ai,j≤103,1≤i≤n,1≤j≤m)(−103≤Ai,j​≤103,1≤i≤n,1≤j≤m)

接下来 qq 行,每行输入 55 个正整数 x1,y1,x2,y2,dx1​,y1​,x2​,y2​,d。(1≤x1≤x2≤n,1≤y1≤y2≤m,−103≤d≤103)(1≤x1​≤x2​≤n,1≤y1​≤y2​≤m,−103≤d≤103)

输出格式

输出 nn 行 mm 个整数,表示操作结束后的矩阵 AA。

样例输入

3 4 3
1 2 2 1
3 2 2 1
1 1 1 1
1 1 2 2 1
1 3 2 3 2
3 1 3 4 1

样例输出

2 3 4 1
4 3 4 1
2 2 2 2

二维差分的举例:

假设我们有一个 4x4 的矩阵,并且我们需要对子矩阵 (1,1)(3,3) 所有元素加 5

 想变成就可以用差分来做

差分数组diff样子

按四点更新规则diff数组会变成这个样子

然后每行从左到右累加:

再然后每列从上到下累加:

下面代码:

#include <iostream>
#include <vector>using namespace std;void solve() {int n, m, q;cin >> n >> m >> q;vector<vector<int>> A(n + 1, vector<int>(m + 1, 0));vector<vector<int>> diff(n + 1, vector<int>(m + 1, 0));for (int i = 1; i <= n; ++i) {for (int j = 1; j <= m; ++j) {cin >> A[i][j];}}for (int i = 0; i < q; ++i) {int x1, y1, x2, y2, d;cin >> x1 >> y1 >> x2 >> y2 >> d;diff[x1][y1] += d;if (x2 + 1 <= n) diff[x2 + 1][y1] -= d;if (y2 + 1 <= m) diff[x1][y2 + 1] -= d;if (x2 + 1 <= n && y2 + 1 <= m) diff[x2 + 1][y2 + 1] += d;}//一步到位的前缀和累加for (int i = 1; i <= n; ++i) {for (int j = 1; j <= m; ++j) {diff[i][j] += diff[i - 1][j];         //累加上方diff[i][j] += diff[i][j - 1];         //累加左方diff[i][j] -= diff[i - 1][j - 1];     //减去重复累加的左上角A[i][j] += diff[i][j];                //更新矩阵元素}}for (int i = 1; i <= n; ++i) {for (int j = 1; j <= m; ++j) {cout << A[i][j] << " ";}cout << endl;}
}int main() {solve();return 0;
}

http://www.dtcms.com/wzjs/836190.html

相关文章:

  • 中山建设网站首页成都软件培训机构排名榜
  • 3yx这个网站做刷单济南手机网站设计
  • 微信公众网站怎么做的wordpress迅雷插件
  • 宁波做公司网站的公司网站建设完成后交付方式
  • 网站定制分享精品源码
  • 在那个网站做任务赚wordpress分类设计
  • wordpress站内seo2022年楼市最新政策
  • 东莞热点网站建设软文营销为什么要讲故事
  • wordpress文章内多页效果点击seo软件
  • 鄂州市门户网站网站数据库有什么用
  • 网站开发范围厦门小鱼网
  • 无锡手机网站制作费用网站常用的优化方法
  • 关于做网站的问卷调查手机网站列表模板
  • 山西省网站旅游网站需求分析怎么做的
  • oracle自带网站开发来年做啥网站致富
  • 无锡网站营销公司简介网站速度慢wordpress
  • 网站百度收录突然消失了运营者邮箱怎么注册
  • 寒亭区建设局网站会员管理网站建设
  • 酒水招商网站大全网站使用网络图片做素材 侵权吗
  • WordPress Grace8.2主题seopeixunwang
  • 网站 mysql数据库 字符wordpress访问插件
  • 毕设给学校做网站wordpress 会员
  • 网站漂浮怎么做蛋糕店网站模板
  • 广东网站开发哪家强顺的网站建设多少钱
  • 淘宝做详情页的网站ui设计技术培训学校
  • 要找人做公司网站应该怎么做建筑工程公司有哪些岗位
  • 网站建设考试试题网站换关键词
  • 电子商务网站的功能分析wordpress布局怎么看
  • 外贸怎么上国外的网站做家具有那个网站好
  • 手术室专科建设网站什么是做网站