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

南昌建站费用怎么学做淘宝免费视频网站

南昌建站费用,怎么学做淘宝免费视频网站,wordpress提示更新英文吧,wordpress mysql 崩溃差分 记录累计差值,相当于输入前缀和数组,计算保留”原数组“,差分和前缀和是互逆操作; 思想 给定我们一个数组a[0],a[1],a[2]....a[n] 我们做一个数组b[0],b[1],b[2]...b[n] b[i]符合b[i]a[i]-a[i-1] 此时b是a的…

差分

记录累计差值,相当于输入前缀和数组,计算保留”原数组“,差分和前缀和是互逆操作;

思想

给定我们一个数组a[0],a[1],a[2]....a[n]

我们做一个数组b[0],b[1],b[2]...b[n]

b[i]符合b[i]=a[i]-a[i-1]

此时b是a的差分,a是b的前缀和

要求在a[l]到a[r]中的所有数都加上c

因为a是b的前缀和,只需要在b[l]+c

a[l]以及a[l]到a[n]所有数,都会+c

只需要在b[r+1]-c,b[r+1]以及b[r+1]到b[n]所有数都会减c

这里的n指的是数组末尾

一维差分经典题目

活动 - AcWing

代码

#include<iostream>
using namespace std;
int sun[100010],arr[100010],xsun[100010];
int main(){int n,m;cin>>n>>m;for(int i=1;i<=n;i++){cin>>sun[i];//求差分,输入的数组是前缀和数组arr[i]=sun[i]-sun[i-1];//求差分数组}while(m--){int l,r,c;cin>>l>>r>>c;//因为sum是arr的前缀和,只需要在arr[l]+c//sun[l]以及sun[l]到sun[n]所有数,都会+c//n是数组最后一个下标arr[l]+=c;//同样,因为因为sum是arr的前缀和,a[r+1]-c//sun[r+1]以及sun[r+1]到sun[n]所有数,都会-carr[r+1]-=c;}for(int i=1;i<=n;i++){xsun[i]=arr[i]+xsun[i-1];//输出改变完值的arr的前缀和数组cout<<xsun[i]<<' ';}return 0;
}

二维差分

题目

活动 - AcWing

思路

把给定的数组当做前缀和数组sun读入,读入的同时求sun的差分,或者说原数组

利用求出的差分数组arr,如果要对一个子矩阵添加删除

只需要对arr数组进行操作,就可以在O(1)的复杂度下批量增删sun数组

假设题目要求对x1,y1,x2,y2子矩阵+c

第一步

假设第二步

实际第二步

上图转换成代码

    	//arr[x1][y1]+c//则其前缀和数组从[x1][y1]开始每个都+carr[x1][y1]+=c;//arr[x2+1][y1]-c,因为只加子矩阵x1,y1,x2,y2//所以去掉多加的部分arr[x2+1][y1]-=c;//这里也是去掉多+的部分arr[x1][y2+1]-=c;//两次去掉多+的部分过程中//有重复删除的部分,把重复删除的部分,添加上一次arr[x2+1][y2+1]+=c;

减完之后,我们就可以求arr的二维前缀和xsun

前缀和

然后输出xsun即可

代码

#include<iostream>
#include<cstdio>
#include<vector>
#include<algorithm>
using namespace std;
int sun[1010][1010],arr[1010][1010],xsun[1010][1010];
int main(){int n,m,q;cin>>n>>m>>q;for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){scanf("%d",&sun[i][j]);//把初始数组当成前缀和数组输入//利用前缀和数组计算原数组//或者说计算差分数组//差分数组通过sun[i][j]减去arr[i][j]+arr[i][j-1]获取//arr[i][j]+arr[i][j-1]的值通过sun不断减去获得//具体过程和求前缀和加法逻辑一样arr[i][j]=sun[i][j]-sun[i-1][j]-sun[i][j-1]+sun[i-1][j-1];}}//q次询问while(q--){int x1,y1,x2,y2,c;cin>>x1>>y1>>x2>>y2>>c;//arr[x1][y1]+c//则其前缀和数组从[x1][y1]开始每个都+carr[x1][y1]+=c;//arr[x2+1][y1]-c,因为只加子矩阵x1,y1,x2,y2//所以去掉多加的部分arr[x2+1][y1]-=c;//这里也是去掉多+的部分arr[x1][y2+1]-=c;//两次去掉多+的部分过程中//有重复删除的部分,把重复删除的部分,添加上一次arr[x2+1][y2+1]+=c;}for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){//求arr的二维前缀和xsun[i][j]=arr[i][j]+xsun[i-1][j]+xsun[i][j-1]-xsun[i-1][j-1];cout<<xsun[i][j]<<" ";}cout<<endl;}return 0;
}

文章转载自:

http://x5abNNwn.grzpc.cn
http://Bk4c6htG.grzpc.cn
http://iNhdSOZY.grzpc.cn
http://fh4VaehP.grzpc.cn
http://NGOxud4w.grzpc.cn
http://LSnyMujD.grzpc.cn
http://MiKEhhPB.grzpc.cn
http://ZfflAeEd.grzpc.cn
http://ALPJL0ho.grzpc.cn
http://vajJN3ys.grzpc.cn
http://Bt4S0Woi.grzpc.cn
http://kjqvW7NH.grzpc.cn
http://veCzuRsY.grzpc.cn
http://wpwzGDTD.grzpc.cn
http://kQny7EHS.grzpc.cn
http://HKsnWaKs.grzpc.cn
http://uXxEwkhs.grzpc.cn
http://98MhbmbJ.grzpc.cn
http://lYmYCrLg.grzpc.cn
http://sn8XMJKI.grzpc.cn
http://hfMpV2nS.grzpc.cn
http://PaPGKjPc.grzpc.cn
http://BrV6KA2z.grzpc.cn
http://6OmgU2N8.grzpc.cn
http://F0ayNujP.grzpc.cn
http://1EderCtJ.grzpc.cn
http://HHbYSxKL.grzpc.cn
http://g59WuEvD.grzpc.cn
http://9TW0QyME.grzpc.cn
http://XJ3nBDBD.grzpc.cn
http://www.dtcms.com/wzjs/775553.html

相关文章:

  • 上海商场网站开发如何做一个营销方案
  • 海安网站建设旅游网站后台html模板
  • 网站建设管理与维护ppt手机网站跳转
  • 企业网站建设大概需要多少钱虫点子创意设计公司
  • 网站备案信息批量查询河北唐山 网站建设
  • 网站仿站工具网络营销包括
  • 网站分哪几类网站建设费用用
  • 农产品网站建设案例竞价单页制作教程
  • 红酒网站建设策划书品牌网站设计公司
  • 株洲做网站多少钱短视频营销平台有哪些
  • 新网 网站建立中国菲律宾会打仗吗现在
  • 物流企业网站建设方案简述app开发流程
  • 贵阳学校网站建设网站用户体验优化方案
  • 手机网站做落地页搜狗搜索旧版本
  • 公司网站建设公司黑龙江 网站建设
  • 网站快速排名优化价格图片编辑在线
  • 国外有哪些做服装的网站有哪些建设工程合同无效工程价款的结算
  • 广州高端网站建设定制怎么让网站绑定域名
  • 长春网站长春网络推广建设域名备案费用
  • 哪个公司做的网站好centos 5.5 wordpress 图片不显示
  • 济南正宗网站建设平台机械营销型网站
  • wordpress 免费空间在门户网站做产品seo
  • 学做网站记不住代码沈阳市建设局网站
  • 网站建设部署与发布试题如何建设网站兴田德润简介呢
  • 东营网站seo外包太原网站推广
  • 个人网站 做导航秦皇岛吧最新事件
  • 济南网站建设(选聚搜网络)广告制作网站源码
  • 网站发外链的好处企业邮箱在哪里看
  • 单位内部网站建设调研上海网站制作服务
  • 怎么创建免费网站吗施工企业管理