hdu 4893Wow! Such Sequence!
多校第三场 7题。。线段树A的
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
#define Lson l,m,rt<<1
#define Rson m+1,r,rt<<1|1
typedef __int64 ll;
int const MAXN = 100010;
ll f[110];
struct Tree{
int l,r;
ll v,s;
int flag;
int add;
}tree[MAXN*6];
ll abss(ll a){
return a<0? -a:a;
}
inline void PushUp(int rt){
tree[rt].v = tree[rt<<1].v + tree[rt<<1|1].v;
tree[rt].s = tree[rt<<1].s + tree[rt<<1|1].s;
}
inline void PushDown(int rt,int m){
if(tree[rt].add){
tree[rt<<1].add = tree[rt].add;
tree[rt<<1|1].add = tree[rt].add;
tree[rt<<1].flag = tree[rt].add * (m - (m>>1));
tree[rt<<1|1].flag = tree[rt].add * (m>>1);
tree[rt<<1].v = tree[rt<<1].s;
tree[rt<<1|1].v = tree[rt<<1|1].s;
tree[rt].add = 0;
}
}
void Build(int l,int r,int rt){
tree[rt].add = 0;
tree[rt].v = 0;
tree[rt].flag = 0;
if(l == r){
tree[rt].s = 1;
return ;
}
int m = (l + r)>>1;
Build(Lson);
Build(Rson);
PushUp(rt);
}
void Update(int k,int d,int l,int r,int rt){
if(k < l || k > r || rt > (MAXN<<2)) return ;
if(l == r){
if(tree[rt].flag){
tree[rt].v = d + tree[rt].s;
tree[rt].flag = 0;
tree[rt].add = 0;
}
else tree[rt].v += d;
int pos = lower_bound(f,f+90,tree[rt].v) - f;
if(pos == 0)tree[rt].s = 1;
else if(abss(f[pos] - tree[rt].v) < abss(f[pos - 1] - tree[rt].v)){
tree[rt].s = f[pos];
}
else tree[rt].s = f[pos-1];
return ;
}
PushDown(rt,r - l + 1);
int m = (l + r)>>1;
if(k <= m) Update(k,d,Lson);
else Update(k,d,Rson);
PushUp(rt);
}
void Change(int L,int R,int l,int r,int rt){
if(R < l || L > r) return ;
if(L <= l && r <= R){
tree[rt].v=tree[rt].s;
tree[rt].add = 1;
tree[rt].flag = r - l + 1;
return ;
}
PushDown(rt,r - l + 1);
int m = (l + r)>>1;
if(L <= m) Change(L,R,Lson);
if(R > m) Change(L,R,Rson);
PushUp(rt);
}
ll Query(int L,int R,int l,int r,int rt){
if(R < l || L > r) return 0;
if(L <= l && r <= R) return tree[rt].v;
PushDown(rt,r - l + 1);
int m =(l + r)>>1;
ll ret = 0;
if(L <= m) ret += Query(L,R,Lson);
if(R > m) ret += Query(L,R,Rson);
return ret;
}
void Init(){
f[0] = 1;
f[1] = 1;
for(int i = 2;i <= 90;i++){
f[i] = f[i - 1] + f[i - 2];
}
}
int main(){
Init();
int n,m;
while(~scanf("%d%d",&n,&m)){
Build(1,n,1);
for(int i = 1;i <= m;i++){
int x;
scanf("%d",&x);
if(x == 1){
int k,d;
scanf("%d%d",&k,&d);
Update(k,d,1,n,1);
}
else if(x == 2){
int x,y;
scanf("%d%d",&x,&y);
printf("%I64d\n",Query(x,y,1,n,1));
}
else if(x == 3){
int x,y;
scanf("%d%d",&x,&y);
Change(x,y,1,n,1);
}
}
}
return 0;
}
/*
1 1
2 1 1
5 4
1 1 7
1 3 17
3 2 4
2 1 5
*/
hdu 4893Wow! Such Sequence!的更多相关文章
- HDU 5860 Death Sequence(死亡序列)
p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...
- HDU 1711 Number Sequence(数列)
HDU 1711 Number Sequence(数列) Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
- HDU 1005 Number Sequence(数列)
HDU 1005 Number Sequence(数列) Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Jav ...
- HDU 5860 Death Sequence(递推)
HDU 5860 Death Sequence(递推) 题目链接http://acm.split.hdu.edu.cn/showproblem.php?pid=5860 Description You ...
- HDU 1560 DNA sequence(DNA序列)
HDU 1560 DNA sequence(DNA序列) Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K ...
- HDU 1005 Number Sequence(数论)
HDU 1005 Number Sequence(数论) Problem Description: A number sequence is defined as follows:f(1) = 1, ...
- HDU 1711 Number Sequence (字符串匹配,KMP算法)
HDU 1711 Number Sequence (字符串匹配,KMP算法) Description Given two sequences of numbers : a1, a2, ...... , ...
- HDU 6078 - Wavel Sequence | 2017 Multi-University Training Contest 4
/* HDU 6078 - Wavel Sequence [ DP ] | 2017 Multi-University Training Contest 4 题意: 给定 a[N], b[M] 要求满 ...
- HDU 6047 - Maximum Sequence | 2017 Multi-University Training Contest 2
/* HDU 6047 - Maximum Sequence [ 单调队列 ] 题意: 起初给出n个元素的数列 A[N], B[N] 对于 A[]的第N+K个元素,从B[N]中找出一个元素B[i],在 ...
随机推荐
- 三:ZooKeeper的ZAB协议
一:ZAB协议概述--->ZooKeeper并没有完全采用Paxos算法,而是使用了一种称为ZooKeeper Atomic Broadcast(ZAB,zookeeper原子消息广播协议)的协 ...
- 【JBPM4】EL表达式的使用,实现JAVA与JPDL的交互
user.java实体类 private String kezhang; private String zhuren; /...完善set get 方法.../ 创建流程实例 //创建流程引擎 Pro ...
- React Native - 5 ListView实现图文混排
首先在根目录下建一个images文件夹,准备好图片 准备datasource 准备图片资源 准备renderRow方法 记得要import相应的类,ListView, Image, Touchable ...
- ubuntu16.04编译安装GPAC
参考:http://blog.csdn.net/tianlong_hust/article/details/9273875 1.获取gpac的源代码 sudo apt-get install subv ...
- 腾讯QQ的聊天记录中的图片记录造假
前不久和朋友在群里聊天时,突然出现了一个BUG,就是一个群友发了A图片,但在我这边显示得却是B图片.当时就猜测,腾讯为了节省流量或者手机资源的原因,给每一张图片弄了个唯一ID,遇到相同ID的就直接从本 ...
- Linux系统运维问题收集
[Q1]如何修改系统时间? #修改成 2016-11-23 11:10:50 A: date -s 11/23/2016 date -s 11:10:50 date -R #查看当前时区和时间 [ ...
- Struts2中的设计模式----ThreadLocal模式
http://www.cnblogs.com/gw811/archive/2012/09/07/2675105.html 设计模式(Design pattern):是经过程序员反复实践后形成的一套代码 ...
- 【计算几何】CDOJ1720 几何几何
#include<cstdio> #include<algorithm> #include<cmath> using namespace std; #define ...
- datatable无法设置横向滚动条(设置无效)
datatable设置横向滚动条无效 js如下: 页面如下: 设置 scrollx 属性为true时,还需在 table 添加 style="white-space: nowrap; &qu ...
- POJ 2139 Six Degrees of Cowvin Bacon (弗洛伊德最短路)
题意:奶牛拍电影,如果2个奶牛在同一场电影里演出,她们的合作度是1,如果ab合作,bc合作,ac的合作度为2,问哪一头牛到其他牛的合作度平均值最小再乘100 思路:floyd模板题 #include& ...