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],在 ...
随机推荐
- ofbiz 之minilang解析
编写一个simple method 首先我们需要对输入参数进行验证 ,判断参数是否完整. 1. 验证 1.1. Login-required :这是一个simple-method的属性,对是否需要登陆 ...
- 最佳 WordPress 静态缓存插件 WP Super Cache 安装和使用(转)
WP Super Cache 是 WordPress 官方开发人员 Donncha开发,是当前最高效也是最灵活的 WordPress 静态缓存插件.它把整个网页直接生成 HTML 文件,这样 Web ...
- WP集成七牛云存储(原创)
借助:七牛镜像存储 WordPress 插件 https://wordpress.org/plugins/wpjam-qiniu/ 安装本插件1.4.5及以上版本,请先安装并激活WPJAM BASIC ...
- gitlab和github的区别
先说一下相同点,二者都是基于web的Git仓库,在很大程度上GitLab是仿照GitHub来做的,它们都提供了分享开源项目的平台,为开发团队提供了存储.分享.发布和合作开发项目的中心化云存 ...
- Android----APP性能优化
性能优化的目标 快 如何让 app 在运行过程过不卡顿,运行流畅,速度快,也就是说如何解决卡顿呢?我们先看看那些因素影响卡顿? UI,包括ui的绘制,刷新等 启动,包括冷启动,热启动,温启动等 跳转, ...
- LR运行场景时出现的error
LR运行场景时出现的error 1.Action.c(24): Error -27740: Overlapped transmission of request to "home.asiai ...
- 转:Python安全 - 从SSRF到命令执行惨案
转:https://www.leavesongs.com/PENETRATION/getshell-via-ssrf-and-redis.html Python安全 - 从SSRF到命令执行惨案 PH ...
- 转:攻击JavaWeb应用[3]-SQL注入
转:http://static.hx99.net/static/drops/tips-236.html 攻击JavaWeb应用[3]-SQL注入 园长 · 2013/07/16 18:28 注:本节重 ...
- POJ 1860 Currency Exchange【SPFA判环】
Several currency exchange points are working in our city. Let us suppose that each point specializes ...
- 推荐Maven的两个仓库
概述 推荐两个maven的仓库,可用于查找依赖,下载jar包. 正文 mvnrepository 这个仓库用来检索依赖.下载jar包:网址:http://mvnrepository.com/ 仓库的主 ...