CodeForces 1109C. Sasha and a Patient Friend
题目简述:维护以下三种操作
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的更多相关文章
- Codeforces 1109D. Sasha and Interesting Fact from Graph Theory
Codeforces 1109D. Sasha and Interesting Fact from Graph Theory 解题思路: 这题我根本不会做,是周指导带飞我. 首先对于当前已经有 \(m ...
- 【Codeforces 1109C 】Sasha and a Patient Friend
Codeforces 1109 C 题意:现在有个碗,每时每刻其中的水量都会加一个整数(可以为负). 给\(n\)个询问,询问有\(3\)种类型: \(1\ t\ s\):将从第\(t\)秒开始水量增 ...
- Codeforces Round #539 (Div. 1) C. Sasha and a Patient Friend 动态开点线段树
题解看这里 liouzhou_101的博客园 更简洁的代码看这里: #include <bits/stdc++.h> using namespace std; typedef long l ...
- 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} 然后就 ...
- 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 ...
- Codeforces 1109F - Sasha and Algorithm of Silence's Sounds(LCT)
Codeforces 题面传送门 & 洛谷题面传送门 讲个笑话,这题是 2020.10.13 dxm 讲题时的一道例题,而我刚好在一年后的今天,也就是 2021.10.13 学 LCT 时做到 ...
- CodeForces 718C Sasha and Array
线段树. 线段树维护区间矩阵和,操作都是最简单的线段树.$lazy$标记不要记录乘了几次,直接记录乘了几次之后的矩阵就可以了,不然每次下传的时候再算一遍时间复杂度会提高. #pragma commen ...
- Codeforces 1109E. Sasha and a Very Easy Test 线段树
原文链接https://www.cnblogs.com/zhouzhendong/p/CF1109E.html 题意 给定一个长度为 n 的数列 a,以及一个模数 M(不一定是质数). 要求支持 q ...
- Codeforces 1109D. Sasha and Interesting Fact from Graph Theory 排列组合,Prufer编码
原文链接https://www.cnblogs.com/zhouzhendong/p/CF1109D.html 题意 所有边权都是 [1,m] 中的整数的所有 n 个点的树中,点 a 到点 b 的距离 ...
随机推荐
- ZOJ - 3430 ac自动机
这题主要就是解码过程很恶心,不能用char存,一共wa了20发 题意:先给n串加密后的字符,然后m串加密后的字符,解码之后求n对应每个m的匹配数,很显然的ac自动机 加密过程是先用对应ascii表的标 ...
- deep learning 学习笔记(三) 线性回归学习速率优化寻找
继续学习http://www.cnblogs.com/tornadomeet/archive/2013/03/15/2962116.html,上一节课学习速率是固定的,而这里我们的目的是找到一个比较好 ...
- derby_学习_00_资源帖
一.精选资料 二.参考资料
- 3.16 draw 3.17 更新函数
3.16 draw virtual void draw(); void HelloWorld::draw() { CCSize size = CCDirector::sharedDirector()- ...
- shell 实现闰年的判断
#!/bin/shecho "please input the year"read year let "n1=$year % 4"let "n2=$y ...
- mysql之 Innobackupex全备恢复(原理、演示)
一. Innobackupex恢复原理 After creating a backup, the data is not ready to be restored. There might b ...
- linux 标准化
Unix 1969 年诞生于 AT&T 贝尔实验室,并在 1973 年使用 C 语言进行了重写,从此就具有了很好的可移植性.但是当 AT&T 在 1984 年由于分拆而得以进入计算机领 ...
- bootstrap-table 父子表入门篇
官方文档:http://bootstrap-table.wenzhixin.net.cn/zh-cn/documentation/#多语言 一.引入js.css <!-- 引入bootstrap ...
- python3入门
简介 计算机基本概念与程序设计语言分类 python风格指南 基础语法 python3 基础语法:基本输入输出 python3 基础语法:标识符和保留字 python3 基础语法:注释 python3 ...
- ASP.NET网站性能提升的几个方法
1. HTTP 压缩 HTTP 压缩通常用于压缩从服务端返回的页面内容.它压缩HTTP请求和响应,这个会是巨大的性能提升.我的项目是基于Window Server 2003开发的,可以参考这篇文章. ...