有n个数和5种操作

add a b c:把区间[a,b]内的所有数都增加c

set a b c:把区间[a,b]内的所有数都设为c

sum a b:查询区间[a,b]的区间和

max a b:查询区间[a,b]的最大值

min a b:查询区间[a,b]的最小值

输入描述 Input Description

第一行两个整数n,m,第二行n个整数表示这n个数的初始值

接下来m行操作,同题目描述

输出描述 Output Description

对于所有的sum、max、min询问,一行输出一个答案

样例输入 Sample Input

10 6

3 9 2 8 1 7 5 0 4 6

add 4 9 4

set 2 6 2

add 3 8 2

sum 2 10

max 1 7

min 3 6

样例输出 Sample Output

49

11

4

数据范围及提示 Data Size & Hint

10%:1<n,m<=10

30%:1<n,m<=10000

100%:1<n,m<=100000

保证中间结果在long long(C/C++)、int64(pascal)范围内

题解:线段树基本操作,区间修改,区间加,区间求最大,最小值;

参考代码:

 #include<cstdio>
#include<algorithm>
#define N 100001
using namespace std;
int n,m,x,y;
long long z;
long long ans;
struct node
{
int l,r,siz;
long long set,add,minn,maxn,sum;
bool v;
}tr[N*];
void up(int k)
{
tr[k].sum=tr[k<<].sum+tr[k<<|].sum;
tr[k].maxn=max(tr[k<<].maxn,tr[k<<|].maxn);
tr[k].minn=min(tr[k<<].minn,tr[k<<|].minn);
}
void build(int k,int l,int r)
{
tr[k].l=l; tr[k].r=r; tr[k].siz=r-l+;
if(l==r)
{
scanf("%d",&x);
tr[k].sum=tr[k].maxn=tr[k].minn=x;
return ;
}
int mid=l+r>>;
build(k<<,l,mid);
build(k<<|,mid+,r);
up(k);
}
void down_set(int k)
{
int l=k<<,r=k<<|;
tr[l].add=tr[r].add=;
tr[l].set=tr[r].set=tr[k].set;
tr[l].v=tr[r].v=true;
tr[l].maxn=tr[r].maxn=tr[l].minn=tr[r].minn=tr[k].set;
tr[l].sum=tr[l].siz*tr[k].set;
tr[r].sum=tr[r].siz*tr[k].set;
tr[k].v=tr[k].set=;
}
void down_add(int k)
{
int l=k<<,r=k<<|;
tr[l].maxn+=tr[k].add;
tr[r].maxn+=tr[k].add;
tr[l].minn+=tr[k].add;
tr[r].minn+=tr[k].add;
tr[l].sum+=tr[l].siz*tr[k].add;
tr[r].sum+=tr[r].siz*tr[k].add;
tr[l].add+=tr[k].add;
tr[r].add+=tr[k].add;
tr[k].add=;
}
void addd(int k)
{
if(tr[k].l>=x&&tr[k].r<=y)
{
tr[k].add+=z;
tr[k].maxn+=z;
tr[k].minn+=z;
tr[k].sum+=z*tr[k].siz;
return;
}
if(tr[k].v) down_set(k);
if(tr[k].add) down_add(k);
int mid=tr[k].l+tr[k].r>>;
if(x<=mid) addd(k<<);
if(y>mid) addd(k<<|);
up(k);
}
void sett(int k)
{
if(tr[k].l>=x&&tr[k].r<=y)
{
tr[k].maxn=tr[k].minn=z;
tr[k].set=z; tr[k].v=true;
tr[k].sum=z*tr[k].siz;
tr[k].add=;
return;
}
if(tr[k].v) down_set(k);
if(tr[k].add) down_add(k);
int mid=tr[k].l+tr[k].r>>;
if(x<=mid) sett(k<<);
if(y>mid) sett(k<<|);
up(k);
}
void query(int k,int w)
{
if(tr[k].l>=x&&tr[k].r<=y)
{
if(w==) ans+=tr[k].sum;
else if(w==) ans=max(ans,tr[k].maxn);
else ans=min(ans,tr[k].minn);
return;
}
if(tr[k].v) down_set(k);
if(tr[k].add) down_add(k);
int mid=tr[k].l+tr[k].r>>;
if(x<=mid) query(k<<,w);
if(y>mid) query(k<<|,w);
}
int main()
{
scanf("%d%d",&n,&m);
build(,,n);
char ch[];
while(m--)
{
scanf("%s",ch);
if(ch[]=='a')
{
scanf("%d%d%lld",&x,&y,&z);
addd();
}
else if(ch[]=='e')
{
scanf("%d%d%lld",&x,&y,&z);
sett();
}
else if(ch[]=='u')
{
scanf("%d%d",&x,&y);
ans=;
query(,);
printf("%lld\n",ans);
}
else if(ch[]=='a')
{
scanf("%d%d",&x,&y);
ans=-;
query(,);
printf("%lld\n",ans);
}
else
{
scanf("%d%d",&x,&y);
ans=1e17;
query(,);
printf("%lld\n",ans);
}
}
}

Codeves 4279 线段树练习5的更多相关文章

  1. bzoj3932--可持久化线段树

    题目大意: 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第 ...

  2. codevs 1082 线段树练习 3(区间维护)

    codevs 1082 线段树练习 3  时间限制: 3 s  空间限制: 128000 KB  题目等级 : 大师 Master 题目描述 Description 给你N个数,有两种操作: 1:给区 ...

  3. codevs 1576 最长上升子序列的线段树优化

    题目:codevs 1576 最长严格上升子序列 链接:http://codevs.cn/problem/1576/ 优化的地方是 1到i-1 中最大的 f[j]值,并且A[j]<A[i] .根 ...

  4. codevs 1080 线段树点修改

    先来介绍一下线段树. 线段树是一个把线段,或者说一个区间储存在二叉树中.如图所示的就是一棵线段树,它维护一个区间的和. 蓝色数字的是线段树的节点在数组中的位置,它表示的区间已经在图上标出,它的值就是这 ...

  5. codevs 1082 线段树区间求和

    codevs 1082 线段树练习3 链接:http://codevs.cn/problem/1082/ sumv是维护求和的线段树,addv是标记这歌节点所在区间还需要加上的值. 我的线段树写法在运 ...

  6. PYOJ 44. 【HNSDFZ2016 #6】可持久化线段树

    #44. [HNSDFZ2016 #6]可持久化线段树 统计 描述 提交 自定义测试 题目描述 现有一序列 AA.您需要写一棵可持久化线段树,以实现如下操作: A v p x:对于版本v的序列,给 A ...

  7. CF719E(线段树+矩阵快速幂)

    题意:给你一个数列a,a[i]表示斐波那契数列的下标为a[i],求区间对应斐波那契数列数字的和,还要求能够维护对区间内所有下标加d的操作 分析:线段树 线段树的每个节点表示(f[i],f[i-1])这 ...

  8. 【BZOJ-3779】重组病毒 LinkCutTree + 线段树 + DFS序

    3779: 重组病毒 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 224  Solved: 95[Submit][Status][Discuss] ...

  9. 【BZOJ-3673&3674】可持久化并查集 可持久化线段树 + 并查集

    3673: 可持久化并查集 by zky Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 1878  Solved: 846[Submit][Status ...

随机推荐

  1. 深入理解计算机系统 第二章 信息的表示和处理 Part1 第二遍

    <深入理解计算机系统> 第三版 第二遍读这本书,每周花两到三小时时间,能读多少读多少(这次看了 22 ~ 28 页) 第一遍对应笔记链接 https://www.cnblogs.com/s ...

  2. Netty学习篇⑤--编、解码

    前言 学习Netty也有一段时间了,Netty作为一个高性能的异步框架,很多RPC框架也运用到了Netty中的知识,在rpc框架中丰富的数据协议及编解码可以让使用者更加青睐: Netty支持丰富的编解 ...

  3. open-falcon监控系统

    官方文档 https://book.open-falcon.org/zh/intro/index.html 一.Open-Falcon介绍 1.监控系统,可以从运营级别(基本配置即可),以及应用级别( ...

  4. pat 1008 Elevator(20 分)

    1008 Elevator(20 分) The highest building in our city has only one elevator. A request list is made u ...

  5. 力扣(LeetCode)两数相加 个人题解

    给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字. 如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和 ...

  6. 力扣(LeetCode)亲密字符串 个人题解

    给定两个由小写字母构成的字符串 A 和 B ,只要我们可以通过交换 A 中的两个字母得到与 B 相等的结果,就返回 true :否则返回 false . 示例 1: 输入: A = "ab& ...

  7. linux磁盘分区、格式化、挂载

    新建分区的操作步骤,如下图: 1)RAID卡: 机器有没有RAID卡可以在开机时看有没有出现配置RAID什么的提示(亲测),系统运行时有没有,不知道! 服务器大多有这个新加硬盘后不修改raid,开即f ...

  8. 2019-9-26:渗透测试,基础学习,js正则以及什么是目录扫描,笔记

    js正则表达式,用单个字符串描述或者匹配符合特定语句规则的字符串,相当于一种搜索模式.一些字符序列组合在一起,可以简单也可以复杂模式的,可以去搜索还可以替换 正则表达式语法/表达式/修饰符(可选),例 ...

  9. (四十六)golang--网络编程(简易的聊天系统)

    Go主要的目标之一就是面向大规模后端服务程序,网络通信这块是服务端程序必不可少也是至关键的一部分. 网络编程有两种: (1)TCP Socket编程:是网络编程的主流,之所以叫TCP Socket编程 ...

  10. Python下定义输出日志

    # 话不多说,直接看代码,,, # -*- coding:UTF-8 -*- # python version: 2.7.15 #脚本名, 日志名,日志路径 import os import sys ...