题目连接就不放了,人类应该反对阴间题目描述

下面给出一个作为正常人能够看懂的题面描述:

给一棵 \(\text{trie}\) 树,可以删掉某一层的所有节点和边。

被删除的节点的子节点会代替当前节点,形成新的一层节点,如果有相同的可以合并。

求删掉哪一层边后合并出的 \(\text{trie}\) 树最小?

考虑 \(\text{trie}\) 的合并。

我们假设已经删去了一个节点,观察下一步会发生什么。

那么接下来一定是这个节点的儿子们所代表的子树合并成一个 \(\text{trie}\) 然后和当前节点的父亲相连。

然后我们来考虑这样一段 \(\text{Trie}\) 树合并的代码:

inline int merge(int x, int y) {
if (x == 0 || y == 0)
return x + y;
int now = ++cnt;
for (int i = 0; i < 26; i++)
son[now][i] = merge(son[x][i], son[y][i]);
return now;
}

相信大家对 \(\text{merge}\) 的流程已经非常熟悉了。

下面我们来考虑新建一个节点的意义:

我们发现在进行一次新建节点时一定是把其中的两个节点合并成为一个点。

所以也就可以直接等价于是删除了原来 \(\text{Trie}\) 树上的一个节点。

我们用 \(num\) 来记录一下此时新删除的节点的数量。

这是删除一个点的情况。

那么我们要删除整整一个层怎么办呢?

直接用 \(\text{dfs}\) 跑一边即可,记得带入 \(deep\) 记录当前的深度。

Code

#include <bits/stdc++.h>

#define file(a) freopen(a".in", "r", stdin), freopen(a".out", "w", stdout)

#define Enter putchar('\n')
#define quad putchar(' ') const int N = 600005; int n, son[N][30], root, ans, maxn, sum[N], cnt;
char c[10]; inline int merge(int x, int y) {
if (x == 0 || y == 0)
return x + y;
int now = ++cnt;
for (int i = 0; i < 26; i++)
son[now][i] = merge(son[x][i], son[y][i]);
return now;
} inline void dfs(int now, int deep) {
int num;
num = cnt = n + 1;
for (int i = 0; i < 26; i++)
if (son[now][i])
num = merge(num, son[now][i]);
sum[deep] += cnt - n - 1;
for (int i = 0; i < 26; i++)
if (son[now][i]) dfs(son[now][i], deep + 1);
} signed main(void) {
// file("CF778C");
std::ios::sync_with_stdio(false);
std::cin.tie(0);
std::cout.tie(0);
std::cin >> n;
root = 1;
for (int i = 1, x, y; i < n; i++) {
std::cin >> x >> y >> c;
son[x][c[0] - 'a'] = y;
}
dfs(1, 1);
for (int i = 1; i <= n; i++)
if (sum[i] > maxn) {
maxn = sum[i];
ans = i;
}
std::cout << n - maxn << std::endl << ans << std::endl;
}

CF778C 题解的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

随机推荐

  1. Fauce:Fast and Accurate Deep Ensembles with Uncertainty for Cardinality Estimation 论文解读(VLDB 2021)

    Fauce:Fast and Accurate Deep Ensembles with Uncertainty for Cardinality Estimation 论文解读(VLDB 2021) 本 ...

  2. Python 函数进阶-迭代器

    迭代器 什么是迭代器 能被 next 指针调用,并不断返回下一个值的对象,叫做迭代器.表示为Iterator,迭代器是一个对象类型数据. 概念 迭代器指的是迭代取值的工具,迭代是一个重复的过程,每次重 ...

  3. Python 查找算法_众里寻他千百度,蓦然回首那人却在灯火阑珊处(线性、二分,分块、插值查找算法)

    查找算法是用来检索序列数据(群体)中是否存在给定的数据(关键字),常用查找算法有: 线性查找: 线性查找也称为顺序查找,用于在无序数列中查找. 二分查找: 二分查找也称为折半查找,其算法用于有序数列. ...

  4. 【笔记】排查CPU占用过高

    本文是该教程视频的笔记 https://www.bilibili.com/video/BV15T4y1y7eH 1. 问题演示 将演示项目打包放到服务器运行 执行 curl http://localh ...

  5. 附011.常见Linux镜像站点大全

    开源系统镜像站点 国内Mirrors站点 企业类站点 阿里巴巴开源Mirrors站点:https://developer.aliyun.com/mirror/ 腾讯开源Mirrors站点:https: ...

  6. 【java并发编程】Lock & Condition 协调同步生产消费

    一.协调生产/消费的需求 本文内容主要想向大家介绍一下Lock结合Condition的使用方法,为了更好的理解Lock锁与Condition锁信号,我们来手写一个ArrayBlockingQueue. ...

  7. 【工具-Nginx】从入门安装到高可用集群搭建

    文章已收录至https://lichong.work,转载请注明原文链接. ps:欢迎关注公众号"Fun肆编程"或添加我的私人微信交流经验 一.Nginx安装配置及常用命令 1.环 ...

  8. Git拉取远程新分支

    1.查看本地分支  git branch 2.查看远程分支  git branch -a 3.如果要拉取的远程分支本地没有 git fetch 4.拉取远程新分支到本地 git checkout -b ...

  9. ML第4周学习小结

    本周收获 总结一下本周学习内容: 1.学习了<深入浅出Pandas>的第五章:Pandas高级操作的两个内容 添加修改数据 高级过滤 我的博客链接: Pandas:添加修改.高级过滤 2. ...

  10. c++ 线段树

    关于线段树 线段数是一种区间树 可以看出:叶子即为输入的数 假设一个节点为 x ,则其左儿子为 2x 右儿子为 2x+1 操作解析 约定 变量名 意义 input[] 输入的数 t[] 线段树 其中 ...