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

廊坊做网站优化的公司手游代理平台代理

廊坊做网站优化的公司,手游代理平台代理,营销型网站建设供货商,设计师一般放作品的网站【题目链接】 ybt 1539:简单题 洛谷 P5057 [CQOI2006] 简单题 【题目考点】 1. 树状数组 模板题及讲解:洛谷 P3374 【模板】树状数组 【解题思路】 解法1:树状数组 该有01构成数组初值都为0。 某位置的元素被修改奇数次后值为1&#x…

【题目链接】

ybt 1539:简单题
洛谷 P5057 [CQOI2006] 简单题

【题目考点】

1. 树状数组

模板题及讲解:洛谷 P3374 【模板】树状数组

【解题思路】

解法1:树状数组

该有01构成数组初值都为0。
某位置的元素被修改奇数次后值为1,被修改偶数次后值为0。
因此只需要求出某位置元素被修改的次数,即可得到该位置的数值。
每次修改是让连续的一段序列翻转,也就是选择数组的一段区间,将该区间中的元素取反(0变为1,1变为0)。
求某元素被修改的次数,就是求有多少个区间覆盖的该元素。
假想存在数组:cL,cR
c L i cL_i cLi表示区间左端点为i的区间数。
c R i cR_i cRi表示区间右端点为i的区间数。
s u m L i sumL_i sumLi c L cL cL的前缀和,即左端点L在[1,i]范围内的区间数
s u m R i sumR_i sumRi c R cR cR的前缀和,右端点R在[1,i]范围内的区间数
分别对cL、cR数组建立树状数组,借助树状数组可以在有单点修改的情况下,以 O ( log ⁡ n ) O(\log n) O(logn)时间复杂度求出序列的前缀和。

如果区间[L, R]包含x,则区间左端点L一定小于等于x。
如果区间[L, R]的右端点R小于x,这样的区间的左端点L也一定小于x。
考察左端点 L ≤ x L\le x Lx的区间,有两类:

  • 右端点 R < x R<x R<x的区间
  • 右端点 R ≥ x R\ge x Rx的区间,即包含x的区间。

左端点 L ≤ x L\le x Lx的区间数量为 s u m L x sumL_x sumLx
右端点 R < x R < x R<x的区间数量为 s u m R x − 1 sumR_{x-1} sumRx1
设包含x的区间的数量为 a n s x ans_x ansx
有: s u m L x = s u m R x − 1 + a n s x sumL_x = sumR_{x-1}+ans_x sumLx=sumRx1+ansx
a n s x = s u m L x − s u m R x − 1 ans_x = sumL_x-sumR_{x-1} ansx=sumLxsumRx1

具体做法:

  1. 如果需要将区间[l, r]中的元素取反,则存在一个区间 [ l , r ] [l, r] [l,r],使 c L l cL_l cLl增加1, c R r cR_r cRr增加1。树状数组进行相应的单点修改操作。
  2. 如果需要查询第x元素的值,则通过 a n s x = s u m L x − s u m R x − 1 ans_x=sumL_x-sumR_{x-1} ansx=sumLxsumRx1求出x被区间修改的次数 a n s x ans_x ansx,如果 a n s x ans_x ansx为奇数,第x元素值为1,否则第x元素值为0。

解法2:线段树 维护区间的异或值

考虑对原数字序列进行区间修改、区间查询。
区间修改的操作为对某区间中每个元素都进行01取反,对于由01构成的序列,01取反操作即为xor 1(异或1)操作。
因为 0 x o r 1 = 1 0\ xor\ 1 = 1 0 xor 1=1 1 x o r 1 = 0 1\ xor\ 1 = 0 1 xor 1=0
区间标记tag设为本段区间中的元素需要被异或的值,即本段区间每个元素实际的值为当前值 x o r t a g \ xor\ tag  xor tag
注意进行区间修改、单点查询前需要进行标记下传。

【题解代码】

解法1:树状数组
  • 写法1:为treeL、treeR设置两套树状数组处理函数
#include<bits/stdc++.h>
using namespace std;
#define N 100005
int n, m, treeL[N], treeR[N];//cL[i]:左端点为i的区间数,treeL:cL的树状数组
int lowbit(int x)
{return x & -x;
}
void updateL(int i)//cL[i]++
{for(int x = i; x <= n; x += lowbit(x))treeL[x]++;
}
void updateR(int i)//cR[i]++
{for(int x = i; x <= n; x += lowbit(x))treeR[x]++;
}
int sumL(int i)//cL的前缀和
{int s = 0;for(int x = i; x > 0; x -= lowbit(x))s += treeL[x];return s;
}
int sumR(int i)//cR的前缀和
{int s = 0;for(int x = i; x > 0; x -= lowbit(x))s += treeR[x];return s;
}
int main()
{ios::sync_with_stdio(false);cin.tie(nullptr);int t, l, r, x;cin >> n >> m;for(int i = 1; i <= m; ++i){cin >> t;if(t == 1){cin >> l >> r;updateL(l);updateR(r);}else{cin >> x;cout << (sumL(x)-sumR(x-1))%2 << '\n';//初值为0,修改偶数次为0,修改奇数次为1 }}return 0;
}
  • 写法2:只设一套树状数组处理函数,传入数组地址
#include<bits/stdc++.h>
using namespace std;
#define N 100005
int n, m, treeL[N], treeR[N];//cL[i]:左端点为i的区间数,treeL:cL的树状数组 cR[i]:右端点为i的区间数,treeR:cR的树状数组
int lowbit(int x)
{return x & -x;
}
void update(int i, int *tree)//cL[i]++,或cR[i]++。
{//传入数组名treeL或treeR,可以修改对应传入的tree数组for(int x = i; x <= n; x += lowbit(x))tree[x]++;
}
int sum(int i, int *tree)//求cL或cR的前缀和
{int s = 0;for(int x = i; x > 0; x -= lowbit(x))s += tree[x];return s;
}
int main()
{ios::sync_with_stdio(false);cin.tie(nullptr);int t, l, r, x;cin >> n >> m;for(int i = 1; i <= m; ++i){cin >> t;if(t == 1){cin >> l >> r;update(l, treeL);update(r, treeR);}else{cin >> x;//x为题目中的i,求x位置的值 cout << (sum(x, treeL)-sum(x-1, treeR))%2 << '\n';//初值为0,修改偶数次为0,修改奇数次为1 }}return 0;
}

解法2:线段树 维护区间异或值

#include<bits/stdc++.h>
using namespace std;
#define N 100005
struct Node
{int val, l, r, tag;
} tree[4*N];
int n, m;
void addTag(int i)
{tree[i].tag ^= 1;tree[i].val ^= 1;
}
void pushDown(int i)
{if(tree[i].tag == 0)return;addTag(2*i);addTag(2*i+1);tree[i].tag = 0;
}
void build(int i, int l, int r)
{tree[i].l = l, tree[i].r = r;if(l == r)//tree[i].val初值都为0 return;int mid = (l+r)/2;build(2*i, l, mid);build(2*i+1, mid+1, r);
}
void update(int i, int l, int r)//a[l]~a[r]取反 
{if(tree[i].r < l || tree[i].l > r)return;if(l <= tree[i].l && tree[i].r <= r)return addTag(i);pushDown(i);update(2*i, l, r);update(2*i+1, l, r);
}
int query(int i, int x)//a[x]
{if(tree[i].l == tree[i].r)return tree[i].val;pushDown(i); if(x <= tree[2*i].r)return query(2*i, x);else//x >= tree[2*i+1].l return query(2*i+1, x);
}
int main()
{ios::sync_with_stdio(false);cin.tie(nullptr);int t, l, r, x;cin >> n >> m;build(1, 1, n);while(m--){cin >> t;if(t == 1){cin >> l >> r;update(1, l, r); }else//t == 2{cin >> x;cout << query(1, x) << '\n';}}return 0;
}

文章转载自:

http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://00000000.ngmjn.cn
http://www.dtcms.com/wzjs/620509.html

相关文章:

  • 公司网站建设服务费怎么做账西安苗木行业网站建设价格
  • 网站建设市场背景dx365.wordpress
  • 商学院网站建设建议淘宝网站策划怎么做
  • 建设小微公司网站需要多少钱海报设计大赛
  • 宁陵县网站seo济南建设信息网站
  • 江苏网站建设工作室湖北网官网
  • 网站建设预计资金投入做视频特效的网站有哪些
  • wordpress能否做网站天水市秦州区作风建设年网站
  • 梅河口网站开发做网站需要哪些基本功能
  • 做网站公司宣传语东莞品牌网站建设多少钱
  • 祥云网站推广WordPress网站属于什么网站
  • wampserver做网站门户网站html下载
  • 网站如何做二级域名如何造网站
  • 怎么用ftp修改网站百度云网盘搜索引擎入口
  • 3gcms企业手机网站整站源码asp外贸网站源码怎么建
  • 建设地情网站的作用荆州网站建设推荐
  • 招聘网站制作公司建设网站有哪些好处
  • wordpress 多个站点网络项目个人怎么推广快
  • 汕头网站推广费用品牌网app下载
  • 网站建设原码现在哪个网站可以做外贸
  • 找小网站的关键词wordpress 内外网
  • 怎样设置个人网站免费永久网站空间
  • 怎样在各大网站做有效的宣传网站开发视频百度云
  • iis网站开发教程长沙网站se0推广优化公司
  • 商标设计网站排行南昌天和建设有限公司网站
  • 滴滴优惠券网站怎么做制作网站程序
  • 家居网站建设哪家好plc编程培训机构
  • 如何做企业网站及费用问题网站建设的十点优势
  • 怎么做那些盗号网站怎么在百度做原创视频网站
  • 贸易公司网站模板新建门户网站的建设自查