#include<stdio.h>

#include<string.h>

#define N 100000

struct st{

 int x,y;

 __int64 yanchi,sum;

}a[N*4];

__int64 b[N];

void build(int t,int x,int y) {

 a[t].x=x;

 a[t].y=y;

 a[t].yanchi=0;

 if(x==y) {

  a[t].sum=b[x];

  return ;

 }

 int temp=t*2;

 int mid=(a[t].x+a[t].y)/2;

 build(temp,x,mid);

 build(temp+1,mid+1,y);

 a[t].sum=a[temp].sum+a[temp+1].sum;

 return ;

}

void change(int t,int x,int y,int z) {

 if(a[t].x==x&&a[t].y==y) {

  a[t].yanchi+=z;

  return ;

 }

 a[t].sum+=(y-x+1)*z;

 int temp=t*2;

 int mid=(a[t].x+a[t].y)/2;

 if(y<=mid)

  change(temp,x,y,z);

 else

  if(x>mid)

   change(temp+1,x,y,z);

  else {

   change(temp,x,mid,z);

   change(temp+1,mid+1,y,z);

  }

  return ;

}

__int64 qury(int t,int x,int y) {

 if(a[t].x==x&&a[t].y==y)

  return a[t].sum+(y-x+1)*a[t].yanchi;

   int temp=t<<1;

   int mid=(a[t].y+a[t].x)/2;

   a[temp+1].yanchi+=a[t].yanchi;

   a[temp].yanchi+=a[t].yanchi;

   a[t].sum+=a[t].yanchi*(a[t].y-a[t].x+1);

   a[t].yanchi=0;

   if(y<=mid)

    return qury(temp,x,y);

   else

    if(x>mid)

     return qury(temp+1,x,y);

    else

     return qury(temp,x,mid)+qury(temp+1,mid+1,y);

}

int main() {

 int i,j,k,n,m;

 char s[100];

 while(scanf("%d%d",&n,&m)!=EOF) {

  for(i=1;i<=n;i++)

   scanf("%I64d",&b[i]);

  build(1,1,n);

  while(m--) {

   scanf("%s",s);

   if(s[0]=='Q') {

    scanf("%d%d",&i,&j);

    printf("%I64d\n",qury(1,i,j));

   }

   else {

    scanf("%d%d%d",&i,&j,&k);

    change(1,i,j,k);

   }

}

 }

 return 0;

}

poj3468区间延迟更新模板题的更多相关文章

  1. hdu 1556 线段树区间延迟更新好题

    656mS #include<stdio.h> #include<stdlib.h> #define N 110000 struct node { int x,y,yanchi ...

  2. FZU Problem 2171 防守阵地 II (线段树区间更新模板题)

    http://acm.fzu.edu.cn/problem.php?pid=2171 成段增减,区间求和.add累加更新的次数. #include <iostream> #include ...

  3. HDU1698:Just a Hook(线段树区域更新模板题)

    http://acm.hdu.edu.cn/showproblem.php?pid=1698 Problem Description In the game of DotA, Pudge’s meat ...

  4. hdu 1698区间延迟更新

    #include<stdio.h> #define N 100100 struct node { int x,y,yanchi; }a[N*4];//注意数组范围 void build(i ...

  5. zoj 1610 Count the Colors(线段树延迟更新)

    所谓的懒操作模板题. 学好acm,英语很重要.做题的时候看不明白题目的意思,我还拉着队友一块儿帮忙分析题意.最后确定了是线段树延迟更新果题.我就欣欣然上手敲了出来. 然后是漫长的段错误.... 第一次 ...

  6. (线段树 区间合并更新)Tunnel Warfare --hdu --1540

    链接: http://acm.hdu.edu.cn/showproblem.php?pid=1540 http://acm.hust.edu.cn/vjudge/contest/view.action ...

  7. POJ - 3264 线段树模板题 询问区间最大最小值

    这是线段树的一个模板题,给出一串数字,然后询问区间的最大最小值. 这个其实很好办,只需把线段树的节点给出两个权值,一个是区间的最小值,一个是区间的最大值,初始化为负无穷和正无穷,然后通过不断地输入节点 ...

  8. hdu1698 Just a Hook 【区间修改】(模板题)

    题目链接:https://vjudge.net/contest/182746#problem/E 题目大意: 一段线段由n条小线段组成,每次操作把一个区间的小线段变成金银铜之一(金的价值为3,银为2, ...

  9. POJ 3468:A Simple Problem with Integers(线段树区间更新模板)

    A Simple Problem with Integers Time Limit: 5000MS   Memory Limit: 131072K Total Submissions: 141093 ...

随机推荐

  1. oracle PL、SQL(概念)

    一.PL/SQL简介. Oracle PL/SQL语言(Procedural Language/SQL)是结合了结构化查询和Oracle自身过程控制为一体的强大语言,PL/SQL不但支持更多的数据类型 ...

  2. Java_静态变量

    class c1c { private static int num = 0; private static double pi = 3.14; private double radius; priv ...

  3. iOS 自己手动添加编译警告

    文/青花瓷的平方(简书作者)原文链接:http://www.jianshu.com/p/b2e30cad2a0d著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 缘由 上一次生产环境我们 ...

  4. 线程池ThreadPoolExecutor参数分析

    概述 比如去火车站买票, 有7个(maximumPoolSize)售票窗口, 但只有3个(corePoolSize)窗口对外开放.那么对外开放的3个窗口称为核心线程数, 而最大线程数是7个窗口. 如果 ...

  5. 【HEVC简介】High Level Syntax

    参考文献:见<High Efficiency Video Coding (HEVC)>High Level Syntax章节 <HEVC标准介绍.HEVC帧间预测论文笔记>系列 ...

  6. monkeyrunner 简单用例编写

    monkeyrunnerfrom com.android.monkeyrunner import MonkeyRunner,MonkeyDevice,MonkeyImagedevice = Monke ...

  7. Android(java)学习笔记173:服务(service)之绑定服务的细节

    绑定服务的细节 1. 如果onbind方法返回值是null,onServiceConnect方法就不会被调用: 2. 绑定的服务,在系统设置界面,正在运行条目是看不到的: 3. 绑定的服务,不求同时生 ...

  8. 我所理解的MVVM

    将UI中的数据适配.交互处理: controller中与UI密切相关的功能: 剥离出来,形成单独的模块: 以增加UI和Controller的灵活性.

  9. java 面试题整理

    java面试题 1.接口和抽象类的区别 抽象类 接口 抽象类中可以有默认方法 在java8之前,不能有默认方法 extends implements 抽象类中可以有构造器 接口中不能有构造器 抽象类中 ...

  10. c语言 预处理的使用 宏展开下的#,##

    1. #include   包含头文件 2.define 宏定义(可以理解为替换,不进行语法检查) 写法 #define 宏名 宏体  加括号 #define ABC (5+3) #define AB ...