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

在什么网站上查建设机械操作证网站推广是什么意思

在什么网站上查建设机械操作证,网站推广是什么意思,游戏运营备案官方网站,皮具网站建设服装网站第五十七章 树状数组(二)一、差分的缺陷二、树状数组与差分三、例题题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1提示样例 1 解释:数据规模与约定代码一、差分的缺陷 差分的作用是能够在O(1)的时间内给一段区间加上相同的数字&am…

第五十七章 树状数组(二)

  • 一、差分的缺陷
  • 二、树状数组与差分
  • 三、例题
    • 题目描述
    • 输入格式
    • 输出格式
    • 样例 #1
      • 样例输入 #1
      • 样例输出 #1
    • 提示
        • 样例 1 解释:
        • 数据规模与约定
    • 代码

一、差分的缺陷

差分的作用是能够在O(1)的时间内给一段区间加上相同的数字,最终查询的时候, 只需要对差分数组求前缀和即可。
但是,如果我们修改一次就想查询一次某个点的值的话。就说明我们需要不断地去求前缀和,即我们每次查询的时间复杂度都是O(n)O(n)O(n)的。这个是非常低效的。

因此,我们就可以利用树状数组来进行优化求解。

二、树状数组与差分

作者在之前的文章中介绍过树状数组与前缀和的关系,没有看过的话,作者建议先去看之前的文章:第五十六章 树状数组(一)

在前缀和+树状数组的题目中,我们是将原数组包装成了树状数组。

而在差分+树状数组的题目中,我们需要将原数组的差分数组写作树状数组的形式。

这样的话,如果给原数组[l,r]内的元素加上一个x的话,我们只需要操作差分数组中的两个点即可。这就又转化为我们在之前的文章中介绍的树状数组的三个函数。

三、例题

洛谷:P3368 【模板】树状数组 2

题目描述

如题,已知一个数列,你需要进行下面两种操作:

  1. 将某区间每一个数加上 xxx

  2. 求出某一个数的值。

输入格式

第一行包含两个整数 NNNMMM,分别表示该数列数字的个数和操作的总个数。

第二行包含 NNN 个用空格分隔的整数,其中第 iii 个数字表示数列第 $i $ 项的初始值。

接下来 MMM 行每行包含 222444个整数,表示一个操作,具体如下:

操作 111: 格式:1 x y k 含义:将区间 [x,y][x,y][x,y] 内每个数加上 kkk

操作 222: 格式:2 x 含义:输出第 xxx 个数的值。

输出格式

输出包含若干行整数,即为所有操作 222 的结果。

样例 #1

样例输入 #1

5 5
1 5 4 2 3
1 2 4 2
2 3
1 1 5 -1
1 3 5 7
2 4

样例输出 #1

6
10

提示

样例 1 解释:

故输出结果为 6、10。


数据规模与约定

对于 30%30\%30% 的数据:N≤8N\le8N8M≤10M\le10M10

对于 70%70\%70% 的数据:N≤10000N\le 10000N10000M≤10000M\le10000M10000

对于 100%100\%100% 的数据:1≤N,M≤5000001 \leq N, M\le 5000001N,M5000001≤x,y≤n1 \leq x, y \leq n1x,yn,保证任意时刻序列中任意元素的绝对值都不大于 2302^{30}230

代码

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 5e5 + 10;
int a[N], b[N], tree[N];
int n, m;int lowbits(int x)
{return x & -x;
}void add(int pos, int x)
{for(int i = pos; i <= n; i += lowbits(i))tree[i] += x;
}int quary(int pos)
{int res = 0;for(int i = pos; i; i -= lowbits(i))res += tree[i];return res;
}void solve()
{cin >> n >> m;for(int i = 1; i <= n; i ++ )cin >> a[i];for(int i = 1; i <= n; i ++ ){b[i] = a[i] - a[i - 1];add(i, b[i]);}while(m -- ){int op;cin >> op;if(op == 1){int l, r, d;cin >> l >> r >> d;add(l, d);add(r + 1, -d);}else{int pos;cin >> pos;cout << quary(pos) << endl;}}}int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);solve();
}
http://www.bjxfkj.com.cn/article/102603.html

相关文章:

  • 中国公路建设在哪个网站公示全网营销软件
  • 建网站公司汽车六万公里是否累变速箱油搜索引擎优化通常要注意的问题有
  • 特微网站首页制作网站费用
  • 做网站需要什么手续资料国外网站开发
  • 成都网站开发建设如何建立一个自己的网站
  • 政府门户网站建设内容开源seo软件
  • 53网站客服系统哪个好百度ai开放平台
  • 网站建设应该怎么做包就业的培训学校
  • 高仿服装网站建设浏览器里面信息是真是假
  • 本地做网站顺序百度行发代理商
  • 长沙开发网站的公司seo怎么搞
  • 成都网站建设价格软文范例大全800字
  • 沈阳网站优化建设软文推广案例500字
  • seo网站程序统计网站流量的网站
  • 江门网站建设公司推广营销策划方案
  • 如何做网站联盟网站友链查询接口
  • 网站平台建设调研报告站长之家是什么网站
  • 我做服装设计师的 求推荐资源网站微商软文范例
  • 企业营销网站服务器1g够学it什么培训机构好
  • 模板网站哪家靠谱岳阳网站建设推广
  • 网站排名的重要性百度指数排名
  • 香港特别行政区区徽平台seo什么意思
  • 上海龙雨建设工程有限公司网站百度电话客服24小时人工
  • ps做的网页怎么导入网站毕节地seo
  • 有没有专业做电视测评的网站阿里域名注册官网
  • 公司网站建设入哪科目2023年最新新闻摘抄
  • 中山制作网站的公司seo关键词排名优化怎样收费
  • 电商营业执照网上申请四川企业seo推广
  • 建设工程造价信息网站外贸seo软件
  • 想推网站目录源码seo资讯