题目大意

给定一个数列,支持区间加一个数和区间取 \(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的更多相关文章

  1. Christmas Trees, Promises和Event Emitters

    今天有同事问我下面这段代码是什么意思: var MyClass = function() { events.EventEmitter.call(this); // 这行是什么意思? }; util.i ...

  2. POJ3160 Father Christmas flymouse[强连通分量 缩点 DP]

    Father Christmas flymouse Time Limit: 1000MS   Memory Limit: 131072K Total Submissions: 3241   Accep ...

  3. Father Christmas flymouse--POJ3160Tarjan

    Father Christmas flymouse Time Limit: 1000MS Memory Limit: 131072K Description After retirement as c ...

  4. POJ3013 Big Christmas Tree[转换 最短路]

    Big Christmas Tree Time Limit: 3000MS   Memory Limit: 131072K Total Submissions: 23387   Accepted: 5 ...

  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 ...

  6. poj 3013 Big Christmas Tree Djistra

    Big Christmas Tree 题意:图中每个节点和边都有权值,图中找出一颗树,树根为1使得 Σ(树中的节点到树根的距离)*(以该节点为子树的所有节点的权值之和) 结果最小: 分析:直接求出每个 ...

  7. BZOJ 3992 序列统计

    Description 小C有一个集合\(S\),里面的元素都是小于\(M\)的非负整数.他用程序编写了一个数列生成器,可以生成一个长度为\(N\)的数列,数列中的每个数都属于集合\(S\). 小C用 ...

  8. 【POJ3710】Christmas Game (博弈-树上的删边问题)

    [题目] Description Harry and Sally were playing games at Christmas Eve. They drew some Christmas trees ...

  9. poj 3710 Christmas Game(树上的删边游戏)

    Christmas Game Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 1967   Accepted: 613 Des ...

  10. POJ 3013 Big Christmas Tree(最短Dijkstra+优先级队列优化,SPFA)

    POJ 3013 Big Christmas Tree(最短路Dijkstra+优先队列优化,SPFA) ACM 题目地址:POJ 3013 题意:  圣诞树是由n个节点和e个边构成的,点编号1-n. ...

随机推荐

  1. .net如何优雅的使用EFCore

    EFCore是微软官方的一款ORM框架,主要是用于实体和数据库对象之间的操作.功能非常强大,在老版本的时候叫做EF,后来.net core问世,EFCore也随之问世. 本文我们将用一个控制台项目Ho ...

  2. Kafka教程(一)基础入门:基本概念、安装部署、运维监控、命令行使用

    Kafka教程(一)基础入门   1.基本概念   背景   领英->Apache   分布式.消息发布订阅系统   角色   存储系统   消息系统   流处理平台-Kafka Streami ...

  3. Linux常用软件的安装及Nginx的使用

    主要内容: 软件安装方式 上传与下载工具 常用软件的安装--jdk.tomcat.mysql.redis 项目的部署 Nginx的安装 Nginx的功能 静态网站部署 虚拟主机配置及端口绑定 域名绑定 ...

  4. org.springframework.jdbc.BadSqlGrammarException: ### Error querying database. Cause: org.postgresql.util.PSQLException: ERROR: operator does not exist: bigint = character varying

    1.报错信息 org.springframework.jdbc.BadSqlGrammarException: ### Error querying database. Cause: org.post ...

  5. 【leetcode】剑指offer04二维数组查找

    很巧妙地把矩阵转化为二叉搜索树(不过好像没什用) class Solution { public: bool findNumberIn2DArray(vector<vector<int&g ...

  6. [py]残留python.exe导致anaconda python路径无法识别

    刚才重下anaconda真是给我整没脾气了 路径啥的都加好了,cmd输入python还是没有,给我跳应用商店去了- 重启也没用 经过一番搜索,找到解决办法: cmd输入"where pyth ...

  7. python + mysql +djagno +unittest 实现WEB、APP UI自动化测试平台--------(一)基础表

    from django.db import models # Create your models here. class DictConfig(models.Model): "" ...

  8. vue3学习第一天

    第一章 Options API与Composition API 重写双向绑定 vue2 基于Object.defineProperty()实现 vue3 基于Proxy proxy与Object.de ...

  9. Kubernetes 部署 - DevOps CI/CD详细指南

    什么是Kubernetes部署?​ 在此文章中,我们将探索Kubernetes(K8s),结合DigitalOcean Kubernetes集群与Buddy自动化运维系统部署以达到以下列出的目标: 使 ...

  10. Java遍历Map集合

    Java遍历Map集合简单例子 import java.util.*; public class Main { public static void main(String[] args) { Has ...