# NOIP2019_Day1T2_括号树

真正的题解——转载Inkyo巨佬%%%

代码:


贴一张代码好了QAQ

#include <bits/stdc++.h> using namespace std; typedef long long ll; const int N = 500010; int n; char a[N]; int fa[N]; int head[N], nxt[N << 1], ver[N << 1], tot; int sta[N], top; ll offer[N], sum[N], ans; void add(int u, int v) { ver[++tot] = v; nxt[tot] = head[u]; head[u] = tot; } void dfs(int now) { if (a[now] == '(') { sta[++top] = now; offer[now] = 0; sum[now] = sum[fa[now]]; for (int i = head[now]; i; i = nxt[i]) { int son = ver[i]; dfs(son); } top--; } else { if (top == 0) { offer[now] = 0; sum[now] = sum[fa[now]]; for (int i = head[now]; i; i = nxt[i]) { int son = ver[i]; dfs(son); } } else { int match = sta[top]; top--; if (a[fa[match]] == ')') { offer[now] = offer[fa[match]] + 1; sum[now] = sum[fa[now]] + offer[now]; } else { offer[now] = 1; sum[now] = sum[fa[now]] + 1; } for (int i = head[now]; i; i = nxt[i]) { int son = ver[i]; dfs(son); } sta[++top] = match; } } return; } int main() { scanf("%d", &n); scanf("%s", a + 1); for (int i = 2; i <= n; i++) { scanf("%d", &fa[i]); add(fa[i], i); } dfs(1); for (int i = 1; i <= n; i++) { ans = ans xor (i * sum[i]); } printf("%lld\n", ans); return 0; }

__EOF__

本文作者熹圜
本文链接https://www.cnblogs.com/Xiwon/p/13402881.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   熹圜  阅读(127)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示