多校第三场 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!的更多相关文章

  1. HDU 5860 Death Sequence(死亡序列)

    p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...

  2. HDU 1711 Number Sequence(数列)

    HDU 1711 Number Sequence(数列) Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...

  3. HDU 1005 Number Sequence(数列)

    HDU 1005 Number Sequence(数列) Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Jav ...

  4. HDU 5860 Death Sequence(递推)

    HDU 5860 Death Sequence(递推) 题目链接http://acm.split.hdu.edu.cn/showproblem.php?pid=5860 Description You ...

  5. HDU 1560 DNA sequence(DNA序列)

    HDU 1560 DNA sequence(DNA序列) Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K  ...

  6. HDU 1005 Number Sequence(数论)

    HDU 1005 Number Sequence(数论) Problem Description: A number sequence is defined as follows:f(1) = 1, ...

  7. HDU 1711 Number Sequence (字符串匹配,KMP算法)

    HDU 1711 Number Sequence (字符串匹配,KMP算法) Description Given two sequences of numbers : a1, a2, ...... , ...

  8. 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] 要求满 ...

  9. 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],在 ...

随机推荐

  1. Distinct Subsequences ——动态规划

    Given a string S and a string T, count the number of distinct subsequences of T in S. A subsequence ...

  2. python 用abc模块构建抽象基类Abstract Base Classes

    见代码: #!/usr/bin/env python # -*- coding: utf-8 -*- # @Time : 2018/08/01 16:58 from abc import ABCMet ...

  3. 最佳 WordPress 静态缓存插件 WP Super Cache 安装和使用(转)

    WP Super Cache 是 WordPress 官方开发人员 Donncha开发,是当前最高效也是最灵活的 WordPress 静态缓存插件.它把整个网页直接生成 HTML 文件,这样 Web ...

  4. android studio 入门比较好的书籍

    http://blog.csdn.NET/aqi00/article/details/50012511 http://blog.csdn.net/aqi00/article/details/73065 ...

  5. 【JBPM4】流程实例变量存取

    设置流程实例变量 //创建流程引擎 ProcessEngine processEngine = Configuration.getProcessEngine(); //获得执行服务 Execution ...

  6. Entity Framework中使用DbCompiledModel中遇到的坑和解决方案

    前段时间,在公司做项目时,引入Entity Framework Code First的方法. 我们公司的软件为SaaS结构,有N个企业注册,其中SQL Server中有一张表为t_User_企业注册号 ...

  7. C/C++ 基础知识

    C/C++ 基础知识 C 语言优秀学习网站 [C Programming Language] C 语言的注释 单行注释 /* comment goes here */ // comment goes ...

  8. 最短路-Bellmanford

    简介: 给定一个图和一个源点,求源点到其余点的最短路径,图中有可能存在负权边. 算法步骤 1.初始化:将除源点外的所有顶点的最短距离估计值 dist[v] ← +∞, dist[s] ←0; 2.迭代 ...

  9. 使用0填充string(构造类似‘00001’的字符串)

    今天在对视频进行爬取的时候,发现url最后是000001,然后是000002,依次增加,而且每一个url请求只能得到一个分段了的视频,这种情况下构造url就成了一个问题. python有一个函数可以处 ...

  10. 北邮校赛 I. Beautiful Array(DP)

    I. Beautiful Array 2017- BUPT Collegiate Programming Contest - sync 时间限制 1000 ms 内存限制 65536 KB 题目描述 ...