【NOIP/CSP2019】D1T2 括号树
原题:
因为是NOIP题,所以首先先看特殊数据,前35分是一条长度不超过2000的链,N^2枚举所有子区间暴力check就能拿到分
其次可以思考特殊情况,一条链的情况怎么做
OI系列赛事的特殊性质分很多时候不仅是帮助得分,还帮助选手找到思路
观察合法串的形状,可以发现主要由括号嵌套和并列组成
嵌套好说,一对匹配的括号对答案贡献为1(里边包的东西不合法的括号不算匹配的括号)
对于并列的括号,可以发现如果要把两对匹配的括号并列算作一个贡献,那么必须要求这两个括号挨着,即右边的左括号的左边是左边的右括号
思考涉及到子区间的问题时,一个常见的思路是确定一个端点,考虑另一个
因为括号匹配是从左到右添加进栈的,那么不妨确定右端点,对于加入的右括号我们只需考虑其能匹配多少个左端点
可以发现,某个右括号和跟他匹配的左括号算1个贡献
如果左括号的左边是匹配上的右括号,那么这个右括号作为右端点的合法区间都可以直接接上右边匹配的一对括号算作贡献1
那么思路就很清楚了,总结一下,只考虑对于匹配上的右括号,有多少个左端点使得区间合法
它自己的左括号算贡献1,然后再把右端点为左括号下标-1的合法区间数接上
用g[i]表示点i为右端点的方案数,f[i]表示g[i]的前缀和(用于统计答案)
那么如果某个点是左括号或匹配不上的右括号,g[i]为0
如果是匹配上左括号j的右括号,g[i]=g[j-1]+1
那么对于一棵树的情况,其实可以发现,只需要dfs树,然后回溯的时候把新加进来的括号退栈就跟序列的情况没什么区别
(当然别忘了刚才退栈的括号回溯时要补进)
代码:
- #include<iostream>
- #include<cstdio>
- #include<algorithm>
- #include<cstring>
- #include<cmath>
- using namespace std;
- #define LL long long
- int rd(){int z=,mk=; char ch=getchar();
- while(ch<''||ch>''){if(ch=='-')mk=-; ch=getchar();}
- while(ch>=''&&ch<=''){z=(z<<)+(z<<)+ch-''; ch=getchar();}
- return z*mk;
- }
- struct edg{int nxt,y;}e[]; int lk[],ltp=;
- void ist(int x,int y){ e[++ltp]=(edg){lk[x],y}; lk[x]=ltp;}
- int n,fth[]; char s[];
- LL f[],g[];
- int q[],hd=;
- void dfs(int x){
- //cout<<"x: "<<x<<" f: "<<f[x]<<" g: "<<g[x]<<endl;
- //for(int i=1;i<=hd;++i) cout<<q[i]<<" ";
- //cout<<endl;
- for(int i=lk[x];i;i=e[i].nxt){
- int tmp=q[hd];
- if(s[e[i].y]==')' && hd){
- g[e[i].y]=g[fth[tmp]]+;
- f[e[i].y]=f[x]+g[e[i].y];
- --hd;
- }
- else{
- if(s[e[i].y]=='(') q[++hd]=e[i].y;
- //因为栈里只会有左括号,所以存下标表示这里有个左括号就vans了
- g[e[i].y]=;
- f[e[i].y]=f[x];
- }
- dfs(e[i].y);
- if(s[e[i].y]==')' && tmp) q[++hd]=tmp;
- //注意不是hd!=0
- else if(s[e[i].y]=='(') --hd;
- }
- }
- int main(){
- freopen("ddd.in","r",stdin);
- cin>>n;
- scanf("%s",s+);
- for(int i=;i<=n;++i) fth[i]=rd(),ist(fth[i],i);
- //q[++hd]=1; f[1]=0,g[1]=0; 注意s[1]不一定是'('
- if(s[]=='(') q[++hd]=; f[]=,g[]=;
- dfs();
- LL ans=;
- for(int i=;i<=n;++i) ans^=i*f[i];
- cout<<ans<<endl;
- return ;
- }
【NOIP/CSP2019】D1T2 括号树的更多相关文章
- 上午小测3 T1 括号序列 && luogu P5658 [CSP/S 2019 D1T2] 括号树 题解
前 言: 一直很想写这道括号树..毕竟是在去年折磨了我4个小时的题.... 上午小测3 T1 括号序列 前言: 原来这题是个dp啊...这几天出了好几道dp,我都没看出来,我竟然折磨菜. 考试的时候先 ...
- 【CSP2019】括号树 题解(递推+链表)
前言:抽时间做了做这道题,把学长送退役的题. ----------------- 题目链接 题目大意:定义$()$是合法括号串.如果$A,B$是合法括号串,那么$(AB),AB$为合法括号串.现给定根 ...
- CSP-S 2019 D1T2 括号树
题目链接:[https://www.luogu.com.cn/problem/P5658] 思路: 这道题不难.(为什么我在考场上一点思路也没有??) 假设我们已经处理到树上的节点u(假设1为根节点) ...
- CSP2019 括号树
Description: 给定括号树,每个节点都是 ( 或 ) ,定义节点的权值为根到该节点的简单路径所构成的括号序列中不同合法子串的个数(子串需要连续,子串所在的位置不同即为不同.)与节点编号的乘积 ...
- P5658 括号树
P5658 括号树 题解 太菜了啥都不会写只能水5分数据 啥都不会写只能翻题解 题解大大我错了 我们手动找一下规律 我们设 w[ i ] 为从根节点到结点 i 对答案的贡献,也就是走到结点 i ,合 ...
- [CSP-S 2019]括号树
[CSP-S 2019]括号树 源代码: #include<cstdio> #include<cctype> #include<vector> inline int ...
- 2021.08.09 P5658 括号树(树形结构)
2021.08.09 P5658 括号树(树形结构) [P5658 CSP-S2019] 括号树 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 题意: 太长,在链接中. 分析及代码 ...
- 【CSP2019 D1T2】【括号树】
题面 不再多说,想必大家都看过这个题 思路 我们可以手推几个满足条件的字符串 我们发现在这些字符串里 每个)都与离它最近的(的匹配 所以我们维护树上每个节点到根节点中没用使用过的(的位置(nl[n]) ...
- 括号树 noip(csp??) 2019 洛谷 P5658
洛谷AC通道 本题,题目长,但是实际想起来十分简单. 首先,对于树上的每一个后括号,我们很容易知道,他的贡献值等于上一个后括号的贡献值 + 1.(当然,前提是要有人跟他匹配,毕竟题目中要求了,是不同的 ...
随机推荐
- Windows 10 下如何彻底关闭 Hyper-V 服务
以管理员身份运行命令提示符 执行命令 bcdedit /set hypervisorlaunchtype off 重启,运行vm即可. 如果想要恢复hyper启动 bcdedit / set hype ...
- Java学习笔记-包,classpath,import,jar
这里介绍Java的包,classpath,import和jar 包(package) 对类文件进行分类管理 给类提供多层命名空间 写在程序文件的第一行 类名的全称的是 包名.类名 包也是一种封装形式 ...
- vue兄弟组件和v-slot之间的关系
如果子组件 没有包含一个 < slot > 元素,则任何传入它的内容都会被抛弃 ,因此我们引入了插槽,可以添加任意内容进子组件.
- eNSP——配置Trunk接口
原理: 在以太网中,通过划分 VLAN 来隔离广播域和增强网络通信的安全性.以太网通常由多台交换机组成,为了使 VLAN 的数据帧跨越多台交换机传递,交换机之间互连的链路需要设置为干道链路( Trun ...
- 深度学习-LeCun、Bengio和Hinton的联合综述
深度学习其实要入门也很简单,不要被深度学习.卷积神经网络CNN.循环神经网络RNN等某些“高大上”的专有名词所吓到或被忽悠,要相信大道至简,一个高中生只要愿意学也完全可以入门级了解并依赖一些成熟的Te ...
- [百度]将ftp添加到本地映射磁盘的方法
在桌面上鼠标双击“计算机”,进入“计算机”窗口 2 在“计算机”窗口中,选择“映射网络驱动器” 3 进入“映射网络驱动器”窗口 4 设置盘符,可以使用默认,也可以自己手动设置 5 在“映射网络驱动器” ...
- Mysql——日期函数,时间操作(汇总)
英文文档连接:https://dev.mysql.com/doc/refman/5.6/en/date-and-time-functions.html 中文文档连接:https://www.docs4 ...
- 【Jmeter源码解读】002——程序入口类NewDriver.java
1.运行环境的检查 2.刚才初始化的 classloader 加载类 org.apache.jmeter.JMeter 然后通过 java 反射的方式来调用 org.apache.jmeter.JMe ...
- IO多路复用技术详解
IO多路复用:I/O是指网络I/O,多路指多个TCP连接(即socket或者channel),复用指复用一个或几个线程.意思说一个或一组线程处理多个TCP连接.最大优势是减少系统开销小,不必创建过 ...
- 顶级Python库
绝不能错过的24个顶级Python库 Python有以下三个特点: · 易用性和灵活性 · 全行业高接受度:Python无疑是业界最流行的数据科学语言 · 用于数据科学的Python库的数量优势 事实 ...