题目简述:维护以下三种操作

1. "1 t s":在时刻$t$插入命令$s$。保证任意操作后,任意时刻至多只有一个命令。

2. "2 t":删除时刻$t$的命令。

3. "3 l r v":求最小的$t \in [l, r]$,使得$f(t)=0$,其中

$$ f(t) = v+\int_l^t g(x) \mathrm{d} x, $$

其中设在$[l, r]$时间内的命令依次为$(t_1, s_1), \dots, (t_m, s_m)$,则

$$ g(t) = \begin{cases}
0 & l \leq t < t_1 \\
s_1 & t_1 \leq t < t_2 \\
\dots \\
s_k & t_k \leq t < t_{k+1} \\
\dots \\
s_m & t \geq t_m
\end{cases}. $$

若不存在,则返回$-1$。

解:code

相关题目:[NOI2005]维护数列

我们将3种操作翻译为以下三种操作:

1. "1 t s":设时刻$t$之后的下一个命令的时刻是$t' > t$。则将$[t, t')$整个区间赋值为$s$。

2. "2 t":设时刻$t$的相邻命令的时刻是$t_1$和$t_2$,满足$t_1 < t < t_2$,并且$t_1$时刻的命令是$s_1$。则将$[t, t_2)$整个区间赋值为$s_1$。

3. "3 l r v":设时刻$l$之后最近的命令在时刻$t_0 \geq l$,令$\mathit{lsum}$表示$[t_0, r)$区间上最小的前缀和,若$v+\mathit{lsum} \leq 0$,则存在时刻$t \in [t_0, r]$,使得$f(t) = 0$。而找到具体的$t$,则可用二分法。

以上三个操作均可用线段树来维护,令

struct node
{
node *Lc, *Rc; //线段树左右儿子
int flag, set; //是否区间赋值,具体赋值
ll lsum, sum; //lsum如上定义,sum为区间求和
};

  

则可以通过以下方式维护信息

void update(node *p)
{
p->sum = p->Lc->sum+p->Rc->sum;
p->lsum = min(p->Lc->lsum, p->Lc->sum+p->Rc->lsum);
}

  

从而时间复杂度为$O(q \log V)$,其中$q$为操作个数,$V$为时刻的取值范围。

注:可预先离散化,或用平衡树来维护,将时间复杂度降至$O(q \log q)$。

CodeForces 1109C. Sasha and a Patient Friend的更多相关文章

  1. Codeforces 1109D. Sasha and Interesting Fact from Graph Theory

    Codeforces 1109D. Sasha and Interesting Fact from Graph Theory 解题思路: 这题我根本不会做,是周指导带飞我. 首先对于当前已经有 \(m ...

  2. 【Codeforces 1109C 】Sasha and a Patient Friend

    Codeforces 1109 C 题意:现在有个碗,每时每刻其中的水量都会加一个整数(可以为负). 给\(n\)个询问,询问有\(3\)种类型: \(1\ t\ s\):将从第\(t\)秒开始水量增 ...

  3. Codeforces Round #539 (Div. 1) C. Sasha and a Patient Friend 动态开点线段树

    题解看这里 liouzhou_101的博客园 更简洁的代码看这里: #include <bits/stdc++.h> using namespace std; typedef long l ...

  4. Codeforces 1109D Sasha and Interesting Fact from Graph Theory (看题解) 组合数学

    Sasha and Interesting Fact from Graph Theory n 个 点形成 m 个有标号森林的方案数为 F(n, m) = m * n ^ {n - 1 - m} 然后就 ...

  5. Codeforces 832A. Sasha and Sticks

    It's one more school day now. Sasha doesn't like classes and is always bored at them. So, each day h ...

  6. Codeforces 1109F - Sasha and Algorithm of Silence's Sounds(LCT)

    Codeforces 题面传送门 & 洛谷题面传送门 讲个笑话,这题是 2020.10.13 dxm 讲题时的一道例题,而我刚好在一年后的今天,也就是 2021.10.13 学 LCT 时做到 ...

  7. CodeForces 718C Sasha and Array

    线段树. 线段树维护区间矩阵和,操作都是最简单的线段树.$lazy$标记不要记录乘了几次,直接记录乘了几次之后的矩阵就可以了,不然每次下传的时候再算一遍时间复杂度会提高. #pragma commen ...

  8. Codeforces 1109E. Sasha and a Very Easy Test 线段树

    原文链接https://www.cnblogs.com/zhouzhendong/p/CF1109E.html 题意 给定一个长度为 n 的数列 a,以及一个模数 M(不一定是质数). 要求支持 q ...

  9. Codeforces 1109D. Sasha and Interesting Fact from Graph Theory 排列组合,Prufer编码

    原文链接https://www.cnblogs.com/zhouzhendong/p/CF1109D.html 题意 所有边权都是 [1,m] 中的整数的所有 n 个点的树中,点 a 到点 b 的距离 ...

随机推荐

  1. vue项目组件的全局注册

    在vue-cli项目中,我们经常会封装自己的组件,并且要在多个界面中引用它,这个时候就需要全局注册组件. 首先我们会封装自己的组件,比如twoDimensionTable文件夹下的index.vue: ...

  2. 在.Net下使用redis基于StackExchange.Redis--登录功能

    研究了下redis在.net下的使用,因为以前在java上用redis用的是jedis操作,在.net不是很熟悉,在网站上也看了一部分的.net下redis的使用,大部分都是ServiceStack. ...

  3. C#中的线程(四)高级话题

    C#中的线程(四)高级话题   Keywords:C# 线程Source:http://www.albahari.com/threading/Author: Joe AlbahariTranslato ...

  4. Codeforces Round #262 (Div. 2)C(二分答案,延迟标记)

    这是最大化最小值的一类问题,这类问题通常用二分法枚举答案就行了. 二分答案时,先确定答案肯定在哪个区间内.然后二分判断,关键在于怎么判断每次枚举的这个答案行不行. 我是用a[i]数组表示初始时花的高度 ...

  5. http请求 详解

  6. Kattis - redblacktree Red Black Tree (树形背包)

    问题:有一课含有n(n<=2e5)个结点的数,有m(m<=1000)个结点是红色的,其余的结点是黑色的.现从树中选若干数量的结点,其中红色的恰有k个,并且每个结点都不是其他任何另一个结点的 ...

  7. RabbitMQ 权限分离&HA操作文档

    概要 默认情况下,使用帐号guest帐号登陆MQ,所有用户的queue信息,全部创建在根目录/的virtual host下,而这样,就会导致,任一用户登录后,都能看到其他用户的queue信息. 针对以 ...

  8. 聊聊“现在学习MFC有用吗?”

    我用MFC做了4年多,后来转到WPF也做了快5年.对于二者,不敢说精通,但应该算入门.结合自己经历,如果不考虑项目需求,我认为新手学习WPF或许更好点.有3点: 1)大家都知道最近几年Motorola ...

  9. 使用Json Template在Azure China创建ARM类型的虚拟机

    前面几篇文章介绍过Azure的两种VM的模式,包括ASM和ARM.并且介绍了如何用Azure CLI和PowerShell创建虚拟机.本文将介绍如何采用Json的Template来创建基于ARM的VM ...

  10. OracleParameter中参数名必须是DB中已有字段:【 ORA-01745: 无效的主机/绑定变量名】

    错误例子: 错误原因:查询的变量是自己随便命名的,不是数据库表中已有的字段, 因此,在进行OracleParameter(":rownum",10)时,在数据库中无法自动进行字段匹 ...