JZOJ 3992.Christmas
题目大意
给定一个数列,支持区间加一个数和区间取 \(max\),询问单点询问数值和它被更改的次数
思路
模板的吉司机线段树
维护区间最小值和严格次小值以及最小值的个数
针对询问维护区间和以及区间修改次数
那么我们可以 \(O(n\log^2 n)\) 解决问题
\(Code\)
#include<cstdio>
#include<iostream>
#define ls (k << 1)
#define rs (ls | 1)
using namespace std;
typedef long long LL;
const int N = 1e5 + 5 , INF = 0x3f3f3f3f;
int n , m , a[N];
struct segment{
LL sum , ch_cnt;
int mn , sec , mn_cnt , tag_add , tag_max , add_cnt , max_cnt;
}seg[N << 2];
inline void pushup(int k)
{
seg[k].sum = seg[ls].sum + seg[rs].sum;
seg[k].ch_cnt = seg[ls].ch_cnt + seg[rs].ch_cnt;
seg[k].mn = min(seg[ls].mn , seg[rs].mn);
if (seg[ls].mn == seg[rs].mn)
{
seg[k].mn_cnt = seg[ls].mn_cnt + seg[rs].mn_cnt;
seg[k].sec = min(seg[ls].sec , seg[rs].sec);
}
else if (seg[ls].mn < seg[rs].mn)
{
seg[k].mn_cnt = seg[ls].mn_cnt;
seg[k].sec = min(seg[ls].sec , seg[rs].mn);;
}
else {
seg[k].mn_cnt = seg[rs].mn_cnt;
seg[k].sec = min(seg[ls].mn , seg[rs].sec);
}
}
inline void push_add(int l , int r , int k , int cnt , int v)
{
seg[k].sum += (r - l + 1LL) * v , seg[k].tag_add += v , seg[k].mn += v;
seg[k].add_cnt += cnt , seg[k].ch_cnt += (r - l + 1LL) * cnt;
if (seg[k].sec < INF) seg[k].sec += v;
if (seg[k].tag_max > -INF) seg[k].tag_max += v;
}
inline void push_max(int k , int cnt , int v)
{
if (v <= seg[k].mn) return;
seg[k].sum += 1LL * (v - seg[k].mn) * seg[k].mn_cnt , seg[k].mn = seg[k].tag_max = v;
seg[k].max_cnt += cnt , seg[k].ch_cnt += 1LL * seg[k].mn_cnt * cnt;
}
inline void pushdown(int l , int r , int k)
{
int mid = (l + r) >> 1;
if (seg[k].add_cnt)
{
push_add(l , mid , ls , seg[k].add_cnt , seg[k].tag_add);
push_add(mid + 1 , r , rs , seg[k].add_cnt , seg[k].tag_add);
seg[k].add_cnt = seg[k].tag_add = 0;
}
if (seg[k].max_cnt)
{
push_max(ls , seg[k].max_cnt , seg[k].tag_max);
push_max(rs , seg[k].max_cnt , seg[k].tag_max);
seg[k].max_cnt = 0 , seg[k].tag_max = -INF;
}
}
inline void build(int l , int r , int k)
{
seg[k].tag_max = -INF;
if (l == r)
{
seg[k].sum = seg[k].mn = a[l];
seg[k].mn_cnt = 1 , seg[k].sec = INF;
return;
}
int mid = (l + r) >> 1;
build(l , mid , ls) , build(mid + 1 , r , rs);
pushup(k);
}
inline void update_add(int l , int r , int k , int x , int y , int c)
{
if (x <= l && r <= y)
{
push_add(l , r , k , c == 0 ? 0 : 1 , c);
return;
}
pushdown(l , r , k);
int mid = (l + r) >> 1;
if (x <= mid) update_add(l , mid , ls , x , y , c);
if (y > mid) update_add(mid + 1 , r , rs , x , y , c);
pushup(k);
}
inline void update_max(int l , int r , int k , int x , int y , int c)
{
if (seg[k].mn >= c) return;
if (x <= l && r <= y && seg[k].sec > c)
{
push_max(k , 1 , c);
return;
}
pushdown(l , r , k);
int mid = (l + r) >> 1;
if (x <= mid) update_max(l , mid , ls , x , y , c);
if (y > mid) update_max(mid + 1 , r , rs , x , y , c);
pushup(k);
}
inline int query_sum(int l , int r , int k , int x)
{
if (l == r && l == x) return seg[k].sum;
pushdown(l , r , k);
int mid = (l + r) >> 1;
if (x <= mid) return query_sum(l , mid , ls , x);
else return query_sum(mid + 1 , r , rs , x);
}
inline int query_ch_cnt(int l , int r , int k , int x)
{
if (l == r && l == x) return seg[k].ch_cnt;
pushdown(l , r , k);
int mid = (l + r) >> 1;
if (x <= mid) return query_ch_cnt(l , mid , ls , x);
else return query_ch_cnt(mid + 1 , r , rs , x);
}
int main()
{
scanf("%d" , &n);
for(register int i = 1; i <= n; i++) scanf("%d" , &a[i]);
build(1 , n , 1);
scanf("%d" , &m);
char op[2];
int l , r , c;
for(; m; m--)
{
scanf("%s" , op);
if (op[0] == 'A')
{
scanf("%d%d%d" , &l , &r , &c);
update_add(1 , n , 1 , l , r , c);
}
else if (op[0] == 'M')
{
scanf("%d%d%d" , &l , &r , &c);
update_max(1 , n , 1 , l , r , c);
}
else{
scanf("%d" , &c);
printf("%d %d\n" , query_sum(1 , n , 1 , c) , query_ch_cnt(1 , n , 1 , c));
}
}
}
JZOJ 3992.Christmas的更多相关文章
- Christmas Trees, Promises和Event Emitters
今天有同事问我下面这段代码是什么意思: var MyClass = function() { events.EventEmitter.call(this); // 这行是什么意思? }; util.i ...
- POJ3160 Father Christmas flymouse[强连通分量 缩点 DP]
Father Christmas flymouse Time Limit: 1000MS Memory Limit: 131072K Total Submissions: 3241 Accep ...
- Father Christmas flymouse--POJ3160Tarjan
Father Christmas flymouse Time Limit: 1000MS Memory Limit: 131072K Description After retirement as c ...
- POJ3013 Big Christmas Tree[转换 最短路]
Big Christmas Tree Time Limit: 3000MS Memory Limit: 131072K Total Submissions: 23387 Accepted: 5 ...
- poj 3013 Big Christmas Tree (最短路径Dijsktra) -- 第一次用优先队列写Dijsktra
http://poj.org/problem?id=3013 Big Christmas Tree Time Limit: 3000MS Memory Limit: 131072K Total S ...
- poj 3013 Big Christmas Tree Djistra
Big Christmas Tree 题意:图中每个节点和边都有权值,图中找出一颗树,树根为1使得 Σ(树中的节点到树根的距离)*(以该节点为子树的所有节点的权值之和) 结果最小: 分析:直接求出每个 ...
- BZOJ 3992 序列统计
Description 小C有一个集合\(S\),里面的元素都是小于\(M\)的非负整数.他用程序编写了一个数列生成器,可以生成一个长度为\(N\)的数列,数列中的每个数都属于集合\(S\). 小C用 ...
- 【POJ3710】Christmas Game (博弈-树上的删边问题)
[题目] Description Harry and Sally were playing games at Christmas Eve. They drew some Christmas trees ...
- poj 3710 Christmas Game(树上的删边游戏)
Christmas Game Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 1967 Accepted: 613 Des ...
- POJ 3013 Big Christmas Tree(最短Dijkstra+优先级队列优化,SPFA)
POJ 3013 Big Christmas Tree(最短路Dijkstra+优先队列优化,SPFA) ACM 题目地址:POJ 3013 题意: 圣诞树是由n个节点和e个边构成的,点编号1-n. ...
随机推荐
- combotree 的简单使用2
上一次我在 combotree 的简单使用 中介绍了一种combotree的写法,不过有一个缺点,就是当输的结构非常大的时候,分级较多时,消耗内存的现象会比较严重,下面介绍的一种方法,使combotr ...
- Python3.9.5安装
参考教程1:https://www.cnblogs.com/xiaoyanhuo/p/16362875.html 参考教程2:https://www.cnblogs.com/feng18/p/5854 ...
- Kafka教程(三):原理及存储
一.思维导图 1.实时更新连接 https://www.mubucm.com/doc/1GRE2U7qYuj 2.思维导图图片 二.具体内容 8.系统架构 架构推导 拓扑结构 多对多 ...
- Linux开发板连接WPA加密的AP路由器
Linux目前有两种方法配置网络: wireless-tools wpa_supplicant iw支持的驱动较多,但只支持WEP加密:wpa_supplicant有部分驱动支持不完善,但支持WEP. ...
- 使用linux的ffmpeg进行B站直播推流
很久之前买了个友善的开发板R2S,一直在家吃灰.最近看到网上有用ffmpeg进行直播推流的案例,想把吃灰的的开发板利用起来,于是有了这篇教程. 第一步:安装ffmpeg sudo apt update ...
- 3、mysql着重号解决关键字冲突
1.着重号(` `): 使用着重号(` `)将字段名或表名括起来解决冲突:保证表中的字段.表名等没有和保留字.数据库系统名或常用方法名冲突
- Django简介以及基本使用
目录 Django简介以及基本使用 一.django简介 1.web框架的本质是什么 ? 2.python主流web框架有那些 ? 3.web框架的推导过程 二.基本使用 1.运行django注意事项 ...
- UOJ33 [UR#2] 树上 GCD
UOJ33 [UR#2] 树上 GCD 简要题意: 给定一棵有根树,对于每个 \(i \in [1,n)\),求出下式的值: \[Ans[i] = \sum_{u<v} \gcd({\rm{di ...
- MQ系列11:如何保证消息可靠性传输(除夕奉上)
MQ系列1:消息中间件执行原理 MQ系列2:消息中间件的技术选型 MQ系列3:RocketMQ 架构分析 MQ系列4:NameServer 原理解析 MQ系列5:RocketMQ消息的发送模式 MQ系 ...
- 04HDFS简介
HDFS简介 一.什么是HDFS HDFS全称是Hadoop Distributed File System,简称HDFS.这是一个分布式文件系统,当数据规模大小超过一台物理计算机的存储能力时,就有必 ...