codeforces 438D
- 在大大推荐下这个标题不明的人做。而我的最后一个非常喜欢的段树,因此,愤怒出手。认为基本上相同。大值,当最大值小于取模时能够剪枝。
- 今后再遇到此类问题算是能攻克了
- // file name: d.cpp //
- // author: huangjipeng //
- // creat time: 2014年05月26日 星期一 16时40分18秒 //
- ///////////////////////////////////////////////////////
- #include<iostream>
- #include<cstdio>
- #include<cstdlib>
- #include<string.h>
- #include<math.h>
- #include<algorithm>
- #include<map>
- #include<vector>
- #include<queue>
- using namespace std;
- #define MAXN 100005
- struct node
- {
- int l,r;
- int mid;
- long long maxx;
- long long sum;
- }tree[MAXN<<2];
- void build(int l,int r,int now)
- {
- tree[now].l=l;
- tree[now].r=r;
- tree[now].mid=(l+r)>>1;
- if(l==r)
- {
- scanf("%I64d",&tree[now].maxx);
- tree[now].sum=tree[now].maxx;
- return ;
- }
- build(l,tree[now].mid,now<<1);
- build(tree[now].mid+1,r,now<<1|1);
- tree[now].sum=(tree[now<<1].sum+tree[now<<1|1].sum);
- tree[now].maxx=max(tree[now<<1].maxx,tree[now<<1|1].maxx);
- }
- long long query(int l,int r,int now)
- {
- if(tree[now].l==l && tree[now].r==r)
- return tree[now].sum;
- if(l>tree[now].mid)
- return query(l,r,now<<1|1);
- else if(r<=tree[now].mid)
- return query(l,r,now<<1);
- else
- return query(l,tree[now].mid,now<<1)+query(tree[now].mid+1,r,now<<1|1);
- }
- void update(int l,int r,long long x,int now)
- {
- if(tree[now].maxx<x)
- return ;
- if(tree[now].l==tree[now].r)
- {
- tree[now].sum=tree[now].sum%x;
- tree[now].maxx=tree[now].sum;
- return ;
- }
- if(l>tree[now].mid)
- update(l,r,x,now<<1|1);
- else if(r<=tree[now].mid)
- update(l,r,x,now<<1);
- else
- {
- update(l,tree[now].mid,x,now<<1);
- update(tree[now].mid+1,r,x,now<<1|1);
- }
- tree[now].sum=tree[now<<1].sum+tree[now<<1|1].sum;
- tree[now].maxx=max(tree[now<<1].maxx,tree[now<<1|1].maxx);
- }
- void op3(int k,long long x,int now)
- {
- if(tree[now].l==k && tree[now].r==k)
- {
- tree[now].maxx=tree[now].sum=x;
- return ;
- }
- if(k>tree[now].mid)
- op3(k,x,now<<1|1);
- else
- op3(k,x,now<<1);
- tree[now].sum=(tree[now<<1].sum+tree[now<<1|1].sum);
- tree[now].maxx=max(tree[now<<1].maxx,tree[now<<1|1].maxx);
- }
- int main()
- {
- int n,m;
- cin>>n>>m;
- build(1,n,1);
- while(m--)
- {
- int op;
- scanf("%d",&op);
- if(op==1)
- {
- int l,r;
- scanf("%d%d",&l,&r);
- cout<<query(l,r,1)<<endl;
- }
- else if(op==2)
- {
- int l,r;
- long long x;
- scanf("%d%d%I64d",&l,&r,&x);
- update(l,r,x,1);
- }
- else if(op==3)
- {
- int k;
- long long x;
- scanf("%d%I64d",&k,&x);
- op3(k,x,1);
- }
- }
- return 0;
- }
版权声明:本文博主原创文章,博客,未经同意不得转载。
codeforces 438D的更多相关文章
- Codeforces 438D (今日gg模拟第二题) | 线段树 考察时间复杂度的计算 -_-|||
Codeforces 438D The Child and Sequence 给出一个序列,进行如下三种操作: 区间求和 区间每个数模x 单点修改 如果没有第二个操作的话,就是一棵简单的线段树.那么如 ...
- Codeforces 438D The Child and Sequence - 线段树
At the children's day, the child came to Picks's house, and messed his house up. Picks was angry at ...
- Codeforces 438D The Child and Sequence
题意:给定一个n个数的序列,完成以下3个操作: 1.给定区间求和 2.给定区间对x取模 3.单点修改 对一个数取模,这个数至少折半.于是我们记一个最大值max,如果x>max则不做处理. #in ...
- 【codeforces 438D】The Child and Sequence
[原题题面]传送门 [大致题意] 给定一个长度为n的非负整数序列a,你需要支持以下操作: 1:给定l,r,输出a[l]+a[l+1]+…+a[r]. 2:给定l,r,x,将a[l],a[l+1],…, ...
- 题解——CodeForces 438D The Child and Sequence
题面 D. The Child and Sequence time limit per test 4 seconds memory limit per test 256 megabytes input ...
- 2018.07.23 codeforces 438D. The Child and Sequence(线段树)
传送门 线段树维护区间取模,单点修改,区间求和. 这题老套路了,对一个数来说,每次取模至少让它减少一半,这样每次单点修改对时间复杂度的贡献就是一个log" role="presen ...
- CodeForces - 438D: The Child and Sequence(势能线段树)
At the children's day, the child came to Picks's house, and messed his house up. Picks was angry at ...
- CodeForces 438D 线段树 剪枝
D. The Child and Sequence time limit per test 4 seconds memory limit per test 256 megabytes input st ...
- CodeForces 438D The Child and Sequence (线段树 暴力)
传送门 题目大意: 给你一个序列,要求在序列上维护三个操作: 1)区间求和 2)区间取模 3)单点修改 这里的操作二很讨厌,取模必须模到叶子节点上,否则跑出来肯定是错的.没有操作二就是线段树水题了. ...
随机推荐
- 使用Intellij Idea生成可执行文件jar,开关exe文件步骤
确保其Java代码是没有问题的,在IDEA常执行的,然后.按以下步骤: 步骤一:打开File -> Project Structure -> Artifacts,例如以下图 步骤二:点击& ...
- 几种流行Webservice控制框架
转会[http://blog.csdn.net/thunder4393/article/details/5787121],写的非常好,以收藏. 1 摘要 开发webservice应用程序中 ...
- 2014年CCNU-ACM暑期集训总结
2014年CCNU-ACM暑期集训总结 那个本期待已久的暑期集训居然就这种.溜走了.让自己有点措手不及.很多其它的是对自己的疑问.自己是否能在ACM这个领域有所成就.带着这个疑问,先对这个暑假做个总结 ...
- 同一个PC只能运行一个应用实例(考虑多个用户会话情况)
原文:同一个PC只能运行一个应用实例(考虑多个用户会话情况) class Program { private static Mutex m; [STAThread] static void Main( ...
- 左右canvas.drawArc,canvas.drawOval 和RectF 关联
1.paint.setStyle(Paint.Style.STROKE) // radius="100dp" // interRadius="40dp" // ...
- List、Map和Set实现类
List.Map和Set实现类 1.List实现类 (1)ArrayList (2)Vector 2.Map实现类 (1)HashMap (2)Hashtable 3.Set实现类 (1)HashSe ...
- vpdn详细说明
VPDN英文为Virtual Private Dial-up Networks,又称为虚拟专用拨号网,是VPN业务的一种,是基于拨号用户的虚拟专用拨号网业务. 中文名 虚拟专用拨号网业务 外文名 ...
- 最短路径:Dijkstra,Bellman,SPFA,Floyd该算法的实施
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMzQ4NzA1MQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQk ...
- ef添加字段
先在实体类里添加字段 ,然后执行 Add-Migration updateNumberOfLikes Update-Database -Verbose
- Atitit. 拉开拉链zip文件 最佳实践实施 java c# .net php
Atitit. 拉开拉链zip文件 的实现最佳实践 java c# .net php 1. Jdk zip 跟apache ant zip 1 2. Apache Ant包进行ZIP文件压缩,upzi ...