CCF GESP 2025年12月认证 C++ 6级

编程题
共 2 道 每题 25 分 共计 50 分
第 1 题
路径覆盖
时间限制:1s 内存限制:512MB

题目描述

给定一棵有 n 个结点的有根树 T,结点依次以 1,2.....n 编号,根结点编号为 1。方便起见,编号为 i 的结点称为结点 i。

初始时 T 中的结点均为白色。你需要将 T 中的若干个结点染为黑色,使得所有叶子到根的路径上至少有一个黑色结点。将结点 i 染为黑色需要代价 $c_i$,你需要在满足以上条件的情况下,最小化染色代价之和。

叶子是指 T 中没有子结点的结点。

输入格式

第一行,一个正整数 n,表示结点数量。

第二行,n-1 个正整数 $f_2,f_3,...,f_n$,其中 $f_i$ 表示结点 i 的父结点的编号,保证 $f_i<i$。

第三行,n 个正整数 $c_1,c_2,...,c_n$,其中 $c_i$ 表示将结点 i 染为黑色所需的代价。

输出格式

一行,一个整数,表示在满足所有叶子到根的路径上至少有一个黑色结点的前提下,染色代价之和的最小值。

样例说明

样例 1

输入:
4
1 2 3
5 6 2 3
输出:
2

样例 2

输入:
7
1 1 2 2 3 3
64 16 15 4 3 2 1
输出:
10

数据范围

对于 40% 的测试点,保证 $2 ≤ n ≤16$。

对于另外 20% 的测试点,保证 $f_i=i-1$。

对于所有测试点,保证 $2 ≤ n ≤10^5,1≤c_i≤10^9$。

第 2 题
道具商店
时间限制:1s 内存限制:512MB

题目描述

道具商店里有 n 件道具可供挑选。第 i 件道具可为玩家提升 $a_i$​ 点攻击力,需要 $c_i$​ 枚金币才能购买,每件道具只能购买一次。现在你有 k 枚金币,请问你最多可以提升多少点攻击力?

输入格式

第一行,两个正整数 n,k,表示道具数量以及你所拥有的金币数量。

接下来 n 行,每行两个正整数 $a_i​,c_i$​,表示道具所提升的攻击力点数,以及购买所需的金币数量。

输出格式

输出一行,一个整数,表示最多可以提升的攻击力点数。

样例说明

样例 1

输入:
3 5
99 1
33 2
11 3
输出:
132

样例 2

输入:
4 100
10 1
20 11
40 33
100 99
输出:
110

数据范围

对于 60% 的测试点,保证 $1≤k≤500,1≤ c_i≤500$。

对于所有测试点,保证 $1≤n≤500,1≤k≤10^9,1≤ a_i≤500,1≤c_i ≤10^9$。

编程题部分已到底了。