Codeforces Round #603 (Div. 2) E. Editor(线段树)
链接:
https://codeforces.com/contest/1263/problem/E
题意:
The development of a text editor is a hard problem. You need to implement an extra module for brackets coloring in text.
Your editor consists of a line with infinite length and cursor, which points to the current character. Please note that it points to only one of the characters (and not between a pair of characters). Thus, it points to an index character. The user can move the cursor left or right one position. If the cursor is already at the first (leftmost) position, then it does not move left.
Initially, the cursor is in the first (leftmost) character.
Also, the user can write a letter or brackets (either (, or )) to the position that the cursor is currently pointing at. A new character always overwrites the old value at that position.
Your editor must check, whether the current line is the correct text. Text is correct if the brackets in them form the correct bracket sequence.
Formally, correct text (CT) must satisfy the following rules:
any line without brackets is CT (the line can contain whitespaces);
If the first character of the string — is (, the last — is ), and all the rest form a CT, then the whole line is a CT;
two consecutively written CT is also CT.
Examples of correct texts: hello(codeforces), round, ((i)(write))edi(tor)s, ( me). Examples of incorrect texts: hello)oops(, round), ((me).
The user uses special commands to work with your editor. Each command has its symbol, which must be written to execute this command.
The correspondence of commands and characters is as follows:
L — move the cursor one character to the left (remains in place if it already points to the first character);
R — move the cursor one character to the right;
any lowercase Latin letter or bracket (( or )) — write the entered character to the position where the cursor is now.
For a complete understanding, take a look at the first example and its illustrations in the note below.
You are given a string containing the characters that the user entered. For the brackets coloring module's work, after each command you need to:
check if the current text in the editor is a correct text;
if it is, print the least number of colors that required, to color all brackets.
If two pairs of brackets are nested (the first in the second or vice versa), then these pairs of brackets should be painted in different colors. If two pairs of brackets are not nested, then they can be painted in different or the same colors. For example, for the bracket sequence ()(())()() the least number of colors is 2, and for the bracket sequence (()(()())())(()) — is 3.
Write a program that prints the minimal number of colors after processing each command.
思路:
先想了线段树,但是不知道怎么维护。
看了题解,发现维护前缀和,前缀和的最大最小值。
最大值判断嵌套深度,最小值没有负数说明满足条件。
代码:
#include<bits/stdc++.h>
using namespace std;
const int MAXN = 1e6+10;
struct Node
{
int sum;
int maxv, minv;
int lazy;
}node[MAXN*4];
char s[MAXN], e[MAXN];
int n, ans[MAXN];
void Build(int root, int l, int r)
{
node[root].sum = node[root].maxv = node[root].minv = node[root].lazy = 0;
if (l == r)
return ;
int mid = (l+r)/2;
Build(root<<1, l, mid);
Build(root<<1|1, mid+1, r);
}
void PushUp(int root)
{
node[root].sum = node[root<<1].sum+node[root<<1|1].sum;
node[root].minv = min(node[root<<1].minv, node[root<<1|1].minv);
node[root].maxv = max(node[root<<1].maxv, node[root<<1|1].maxv);
}
void PushDown(int root, int l, int r)
{
if (node[root].lazy != 0)
{
int mid = (l+r)/2;
node[root<<1].lazy += node[root].lazy;
node[root<<1|1].lazy += node[root].lazy;
node[root<<1].sum += node[root].lazy*(mid-l+1);
node[root<<1|1].sum += node[root].lazy*(r-mid);
node[root<<1].minv += node[root].lazy;
node[root<<1|1].minv += node[root].lazy;
node[root<<1].maxv += node[root].lazy;
node[root<<1|1].maxv += node[root].lazy;
node[root].lazy = 0;
}
}
void Update(int root, int l, int r, int ql, int qr, int v)
{
if (qr < l || r < ql)
return;
if (ql <= l && r <= qr)
{
node[root].sum += (r-l+1)*v;
node[root].maxv += v;
node[root].minv += v;
node[root].lazy += v;
return;
}
PushDown(root, l, r);
int mid = (l+r)/2;
Update(root<<1, l, mid, ql, qr, v);
Update(root<<1|1, mid+1, r, ql, qr, v);
PushUp(root);
}
int QuerySum(int root, int l, int r, int p)
{
if (l == r)
return node[root].sum;
int mid = (l+r)/2;
PushDown(root, l, r);
if (p <= mid)
return QuerySum(root<<1, l, mid, p);
else
return QuerySum(root<<1|1, mid+1, r, p);
}
int main()
{
scanf("%d", &n);
scanf("%s", s);
Build(1, 1, n);
int p = 1, len = strlen(s);
for (int i = 0;i < len;i++)
{
if (s[i] == 'L')
{
if (p>1)
p--;
}
else if (s[i] == 'R')
p++;
else
{
if (s[i] == '(' && e[p] == ')')
Update(1, 1, n, p, n, 2);
else if (s[i] == ')' && e[p] == '(')
Update(1, 1, n, p, n, -2);
else if (s[i] == '(' && e[p] != '(')
Update(1, 1, n, p, n, 1);
else if (s[i] == ')' && e[p] != ')')
Update(1, 1, n, p, n, -1);
else if (s[i] != '(' && s[i] != ')')
{
if (e[p] == '(')
Update(1, 1, n, p, n, -1);
else if (e[p] == ')')
Update(1, 1, n, p, n, 1);
}
e[p] = s[i];
}
int sum = QuerySum(1, 1, n, n);
// cout << sum << endl;
int minv = node[1].minv;
if (sum == 0 && minv >= 0)
ans[i] = node[1].maxv;
else
ans[i] = -1;
}
for (int i = 0;i < len;i++)
cout << ans[i] << ' ';
cout << endl;
return 0;
}
Codeforces Round #603 (Div. 2) E. Editor(线段树)的更多相关文章
- Codeforces Round #603 (Div. 2) E. Editor 线段树
E. Editor The development of a text editor is a hard problem. You need to implement an extra module ...
- Codeforces Round #603 (Div. 2) E. Editor
E. Editor 题目链接: https://codeforces.com/contest/1263/problem/E 题目大意: 输入一个字符串S1含有‘(’ , ‘)’ , ‘R’ , ‘L’ ...
- Codeforces Codeforces Round #316 (Div. 2) C. Replacement 线段树
C. ReplacementTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/570/problem ...
- Codeforces Round #406 (Div. 1) B. Legacy 线段树建图跑最短路
B. Legacy 题目连接: http://codeforces.com/contest/786/problem/B Description Rick and his co-workers have ...
- Codeforces Round #765 Div.1 F. Souvenirs 线段树
题目链接:http://codeforces.com/contest/765/problem/F 题意概述: 给出一个序列,若干组询问,问给出下标区间中两数作差的最小绝对值. 分析: 这个题揭示着数据 ...
- 【转】Codeforces Round #406 (Div. 1) B. Legacy 线段树建图&&最短路
B. Legacy 题目连接: http://codeforces.com/contest/786/problem/B Description Rick and his co-workers have ...
- Codeforces Round #406 (Div. 2) D. Legacy 线段树建模+最短路
D. Legacy time limit per test 2 seconds memory limit per test 256 megabytes input standard input out ...
- Codeforces Round #278 (Div. 1) Strip (线段树 二分 RMQ DP)
Strip time limit per test 1 second memory limit per test 256 megabytes input standard input output s ...
- Codeforces Round #603 (Div. 2) E - Editor(线段树,括号序列)
随机推荐
- [转帖]direct path read直接路径读
direct path read直接路径读 http://blog.itpub.net/12679300/viewspace-1188072/ 原创 Oracle 作者:wzq609 时间:2014- ...
- [转帖]linux find -regex 使用正则表达式
linux find -regex 使用正则表达式 https://www.cnblogs.com/jiangzhaowei/p/5451173.html find之强大毋庸置疑,此处只是带领大家一窥 ...
- python实现根据前序与中序求后序
我就不板门弄斧了求后序 class Tree(): def __init__(self,x): self.value=x self.left=None self.right=None class So ...
- jar包部署脚本
部署一个名为xxx的jar包,输出到out.log,只需要准备以下脚本start.sh #!/bin/sh echo " =====关闭Java应用======" PROCESS= ...
- css z-index 的学习
前言:这是笔者第一次写博客,主要是学习之后自己的理解.如果有错误或者疑问的地方,请大家指正,我会持续更新! z-index属性描述元素的堆叠顺序(层级),意思是 A 元素可以覆盖 B 元素,但是 B ...
- 基于Jquery的下拉列表控件(个人觉得实用)
Selectize.js Selectize 是一个基于 jQuery 的 <select> UI 控件,对于标签选择和下拉列表功能非常有用. Selectize 的目标是通过简单而强大的 ...
- 服务发现框架选型: Consul、Zookeeper还是etcd ?
背景 本文并不介绍服务发现的基本原理.除了一致性算法之外,其他并没有太多高深的算法,网上的资料很容易让大家明白上面是服务发现.想直接查看结论的同学,请直接跳到文末.目前,市面上有非常多的服务发现工具, ...
- java加密解密工具类
package com.founder.mrp.util; import java.nio.charset.StandardCharsets; import java.security.Key; im ...
- Spring Security OAuth2.0 - AuthorizationServer和ResourceServer分离
<Spring Security实现OAuth2.0授权服务 - 基础版>和<Spring Security实现OAuth2.0授权服务 - 进阶版>两篇文章中介绍如何搭建OA ...
- MFC中动态添加控件----寻找多年的秘籍,吐血推荐
原文作者tianwaik 动态控件是指在需要时由Create()创建的控件,这与预先在对话框中放置的控件是不同的. 一.创建动态控件 为了对照,我们先来看一下静态控件的创建. 放置静态控件时必须先建立 ...