CCPC-Wannafly Winter Camp Day8 (Div1, onsite) 题解+代码(ABEG)

2023-11-30 14:40

本文主要是介绍CCPC-Wannafly Winter Camp Day8 (Div1, onsite) 题解+代码(ABEG),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

比赛链接:(Onsite) (Online mirror)

A. Aqours(13 通过,已补题)

其实就是一个挺简单的树上问题。。。当时没时间看这道题,血亏。。。但是需要注意,这道题输入量高达$3 \cdot 10^6$,最好使用快读,不然很可能被卡常数。

出题人题解:给出的点可以视为是按照 BFS 序给的,也就是说从浅到深给出。可以再给每个节点 u 维护一个 f_u 值, 表示离 u 最近的叶子节点到它的距离。所以每当扫到一个叶子节点,就可以暴力往根节点跳,边跳边更新 f 值,直到跳到一个已被其他叶子节 点跳到过的节点为止。 那么对于当前的叶子节点,离它最近的编号小于它的叶子节点到它的距离就是跳到这个终止节点的 f 值 +跳的步数。 在求完之后,还要从上述的终止节点沿着原路更新一下 f 值,因为可能当前叶子比较深但之前有比较浅 的叶子节点。 因为点是按从浅到深的顺序给出,所以一个节点的 f 值只会被最先跳到它的叶子节点赋值一次,也只会被更新一次,所以复杂度是 O(n) 的。

Status: 已补题(2019-01-29)


#include<bits/stdc++.h>
#define rep(i, n) for(int i = 1; i <= n; ++i)
using namespace std;
typedef long long ll;const int BUFF_SIZE = 1 << 20;
char BUFF[BUFF_SIZE],*BB,*BE;
#define gc() (BB == BE ? (BE = (BB = BUFF) + fread(BUFF,1,BUFF_SIZE,stdin),BB == BE ? EOF : *BB++) : *BB++)template<typename T> void read(T &x){x = 0; int f = 1; char ch = gc();while(!isdigit(ch) ) { if(ch == '-') f = -1; ch = gc();}while( isdigit(ch) ) {x = x * 10 + ch - 48; ch = gc();}x *= f;
}const int MAXN = 100200;
int fa[MAXN], n, f[MAXN], root = 1;
vector<int> G[MAXN], leaf;inline void link(int x, int y) {G[x].push_back(y);G[y].push_back(x);
}int main() {memset(f, -1, sizeof f);read(n);if(n == 1) { puts("1 -1"); return 0; }for(int i = 2; i <= n; ++i)read(fa[i]), link(i, fa[i]);for(int i = 2; i <= n; ++i) if(G[i].size() == 1u) leaf.push_back(i);for(auto v : leaf) {int p = v, cnt = -1;printf("%d ", v);while(p != root && f[p] == -1)f[p] = ++cnt, p = fa[p];if(p == root && f[p] == -1) {f[p] = ++cnt;puts("-1");} else {printf("%d\n", cnt + f[p] + 1);}f[p] = min(f[p], cnt + 1);int to = p, cur = cnt + f[p] + 1; p = fa[v];while(p != to) {f[p] = min(f[p], --cur);p = fa[p];}}return 0;
}

 

B. 玖凛两开花(34 通过,场上AC)

要求的是一个最小值的最大,很容易联想到二分。假设答案是x,则0, 1, ..., x - 1这些数一定要被匹配,显然有贪心结论:0, 1, ..., x - 1之间一定不能连边。那么把0, 1, ..., x - 1放在一边,x, x + 1, ..., n - 1放在另一边,跑最大匹配,这就是一个二分图匹配问题,可以用Dinic解决。复杂度

这篇关于CCPC-Wannafly Winter Camp Day8 (Div1, onsite) 题解+代码(ABEG)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/437421

相关文章

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

java之Objects.nonNull用法代码解读

《java之Objects.nonNull用法代码解读》:本文主要介绍java之Objects.nonNull用法代码,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录Java之Objects.nonwww.chinasem.cnNull用法代码Objects.nonN

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

在C#中调用Python代码的两种实现方式

《在C#中调用Python代码的两种实现方式》:本文主要介绍在C#中调用Python代码的两种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#调用python代码的方式1. 使用 Python.NET2. 使用外部进程调用 Python 脚本总结C#调

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时