括号树 noip(csp??) 2019 洛谷 P5658
本题,题目长,但是实际想起来十分简单。
首先,对于树上的每一个后括号,我们很容易知道,他的贡献值等于上一个后括号的贡献值 + 1。(当然,前提是要有人跟他匹配,毕竟题目中要求了,是不同的子串。)
那么,如何记录是否有人跟他匹配?? 也很好想。。。 用一个栈来维护(同时也方便我们记录上一个后括号所在的位置。)
那么,求总贡献值呢?? 更好办了。 直接等于他爸爸 + 他自己的呗!!
结束了~~~
#include <bits/stdc++.h>
using namespace std;
#define N 600010
#define ll long long inline ll read(){
ll x = , s = ;
char c = getchar();
while(!isdigit(c)){
if(c == '-')s = -;
c = getchar();
}
while(isdigit(c)){
x = (x << ) + (x << ) + (c ^ '');
c = getchar();
}
return x * s;
} int fa[N];
ll sum[N], lst[N]; struct node{
int v, next;
} t[N];
int f[N];
int a[N];
char c[N]; int bian = ;
inline void add(int u, int v){
t[++bian] = (node){v, f[u]};
f[u] = bian;
return ;
} int stac[N], top = ;
void dfs(int now){
int temp = ;;
if(c[now] == '('){
stac[++top] = now;
}
else if(c[now] == ')'){
if(top){
temp = stac[top];
lst[now] = lst[fa[temp]] + ;
top--;
}
}
sum[now] = sum[fa[now]] + lst[now];
for(int i = f[now]; i; i = t[i].next){
int v = t[i].v;
dfs(v);
}
if(temp != ) stac[++top] = temp;
else if(top) top--;
return ;
} int main(){
int n = read();
scanf("%s", c + );
for(int i = ;i <= n; i++){
int x = read();
add(x, i);
fa[i] = x;
}
dfs();
ll ans = ;
for(ll i = ;i <= n; i++)
ans ^= i * sum[i];
printf("%lld\n", ans);
return ;
}
括号树 noip(csp??) 2019 洛谷 P5658的更多相关文章
- 格雷码 CSP(NOIP??)2019  洛谷 P5657
		
洛谷AC通道! 多年过后,重新来看这道D1T1,20min不到AC,再回忆起当初考场三小时的抓耳挠腮,不禁感慨万千啊!! 发篇题解记录一下. 思路:直接dfs模拟即可(二进制找规律是不可能的, 这辈子 ...
 - 【noip】跟着洛谷刷noip题2
		
noip好难呀. 上一个感觉有点长了,重开一个. 36.Vigenère 密码 粘个Openjudge上的代码 #include<cstdio> #include<iostream& ...
 - 【noip】跟着洛谷刷noip题
		
传送门 1.铺地毯 d1t1 模拟 //Twenty #include<cstdio> #include<cstdlib> #include<iostream> # ...
 - 树链剖分模板(洛谷P3384)
		
洛谷P3384 #include <bits/stdc++.h> #define DBG(x) cerr << #x << " = " < ...
 - 线段树分治初步学习&洛谷P5227[AHOI2013]连通图
		
线段树分治 其实思想说起来是比较简单的,我们把这个题里的所有操作(比如连边删边查询balabala)全部拍到一棵线段树上,然后对着整棵树dfs一下求解答案,顺便把操作做一下,回溯的时候撤销一下即可.虽 ...
 - 李超线段树(segment[HEOI2013]-洛谷T4097)
		
(neng了好久好久才糊弄懂得知识点...) 一.李超线段树 在线动态维护一个二维平面直角坐标系, 支持插入一条线段, 询问与直线x = x0相交的所有线段中,交点y的最大/小值 (若有多条线段符合条 ...
 - 树剖模板(洛谷P3384 【模板】树链剖分)(树链剖分,树状数组,树的dfn序)
		
洛谷题目传送门 仍然是一个板子. 不过蒟蒻去学了一下BIT维护区间修改区间求和,常数果真十分优秀 设数列为\(a_i\),差分数组\(d_ i=a_ i-a_ {i-1}\),前缀和\(s_i=\su ...
 - 【CSP-S 2019】【洛谷P5658】括号树【dfs】【二分】
		
题目: 题目链接:https://www.luogu.org/problem/P5658?contestId=24103 本题中合法括号串的定义如下: () 是合法括号串. 如果 A 是合法括号串,则 ...
 - 题解【洛谷P5658】[CSP-S 2019]括号树
		
题面 一道简单的栈与\(\text{DP}\)的结合. 首先介绍一下序列上的括号匹配问题,也就是此题在序列上的做法: 设 \(dp_i\) 表示以 \(i\) 结尾的合法的括号序列个数, \(ss_i ...
 
随机推荐
- 一只简单的网络爬虫(基于linux C/C++)————线程相关
			
爬虫里面采用了多线程的方式处理多个任务,以便支持并发的处理,把主函数那边算一个线程的话,加上一个DNS解析的线程,以及我们可以设置的max_job_num值,最多使用了1+1+max_job_num个 ...
 - 一个简单的wed服务器SHTTPD(1)————命令行和文件配置解析
			
开始学习<LInux网络编程>中的综合案例,虽然代码书上有,还是自己打一下加深理解和印象. 主要有两个函数,完成命令行的解析,另一个实现配置文件的解析,注释还是比较丰富的哦. //star ...
 - docker 生产环境基础应用
			
项目背景 此项目是在已有项目基础上,开发的一套相对独立的系统.项目总体分为三部分,前端.中间应用服务.流媒体服务.前端技术选型为vue+elementui,中间应用服务为.net core webap ...
 - windows脱密码总结
			
方式1:通过SAM数据库获得本地用户HASH sam文件:是用来存储本地用户账号密码的文件的数据库system文件:里面有对sam文件进行加密和加密的密钥 利用方式: 导出sam和system: re ...
 - B. Marvolo Gaunt's Ring  前缀后缀
			
B. Marvolo Gaunt's Ring 这种一般只有三个的都可以处理前缀和后缀,再枚举中间这个值. 这个和之前写过的C. Four Segments 前缀后缀 处理方式很像. #include ...
 - mybatis控制台打印执行的sql语句
 - Spring杂谈 | 你真的了解泛型吗?从java的Type到Spring的ResolvableType
			
关于泛型的基本知识在本文中不会过多提及,本文主要解决的是如何处理泛型,以及java中Type接口下对泛型的一套处理机制,进而分析Spring中的ResolvableType. 文章目录 Type 简介 ...
 - Spring官网阅读(四)BeanDefinition(上)
			
前面几篇文章已经学习了官网中的1.2,1.3,1.4三小结,主要是容器,Bean的实例化及Bean之间的依赖关系等.这篇文章,我们继续官网的学习,主要是BeanDefinition的相关知识,这是Sp ...
 - 多线程高并发编程(9) -- CopyOnWrite写入时复制
			
CopyOnWrite写入时复制 CopyOnWrite,即快照模式,写入时复制就是不同线程访问同一资源的时候,会获取相同的指针指向这个资源,只有在写操作,才会去复制一份新的数据,然后新的数据在被写操 ...
 - Centos最小安装
			
网络配置 虚拟机安装使用的NAT模式 #enoXXX 为自己的网卡名称, 使用ip addr 可以查看 将/etc/sysconfig/network-scripts/ifcfg-enoXXX中的ON ...