CF778C 题解
题目连接就不放了,人类应该反对阴间题目描述
下面给出一个作为正常人能够看懂的题面描述:
给一棵 \(\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 题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
随机推荐
- Java Windows下读取注册表的工具类
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import ...
- Python连接数据库,列表输出数据库中的某一列
1 import pymysql 2 import pandas as pd 3 import numpy as np 4 #连接数据库,地址,端口,用户名,密码,数据库名称,数据格式 5 conn ...
- Python抽象基类:ABC谢谢你,因为有你,温暖了四季!
Python抽象基类:ABC谢谢你,因为有你,温暖了四季! Python抽象基类:ABC谢谢你,因为有你,温暖了四季! 实例方法.类方法和静态方法 抽象类 具名元组 参考资料 最近阅读了<Pyt ...
- SpringBoot 如何统一后端返回格式
在前后端分离的项目中后端返回的格式一定要友好,不然会对前端的开发人员带来很多的工作量.那么SpringBoot如何做到统一的后端返回格式呢?今天我们一起来看看. 为什么要对SpringBoot返回统一 ...
- python数据可视化-matplotlib入门(6)-从文件中加载数据
前几篇都是手动录入或随机函数产生的数据.实际有许多类型的文件,以及许多方法,用它们从文件中提取数据来图形化. 比如之前python基础(12)介绍打开文件的方式,可直接读取文件中的数据,扩大了我们的数 ...
- TCP 协议灵魂 12 问,巩固你的网路底层基础!
点击上方"开源Linux",选择"设为星标" 回复"学习"获取独家整理的学习资料! 先亮出这篇文章的思维导图 TCP 作为传输层的协议,是一 ...
- 浅谈 UNIX、Linux、ios、android 他们之间的关系
开源Linux 一个执着于技术的公众号 Unix, 简化形成了Linux,Linux则是Android的内核,而苹果则是使用unix系统作为ios和macos的内核. 几个系统出现的时间 UNIX系统 ...
- JavaScript 数据结构与算法2(队列和双端队列)
学习数据结构的 git 代码地址: https://gitee.com/zhangning187/js-data-structure-study 1.队列和双端队列 队列和栈非常类似,但是使用了与 后 ...
- CTF中常见密码学
前言 参考,我们任课老师的WORD和PPT,结合自己的理解,在结合网上文章的理解. 一.BASE64编码 BASE64编码中,特征和所拥有的字符字母:A-Z a-z;数字:0-9;符号:+ / ,然后 ...
- EF Core 配置模型
0 前言 本文的第一节,会概述配置模型的作用(对数据模型的补充描述). 第二节描述两种配置方式,即:数据注释(data annotations)和 Fluent API 方式. 第三节开始,主要是将常 ...