选择题 共15道
判断题 共10道
编程题 共2道
已知小写字母 b 的ASCII码为98,下列C++代码的输出结果是( )。
下面程序的输出为( )。
下面 init_sieve 函数的时间复杂度为( )。
下列选项中,哪个不可能是下图的深度优先遍历序列( )。
unsigned long long 类型是C++语言中表达范围最大的非负整数类型之一,其表达范围是 。超出该范围的非负整数运算,将无法使用C++语言进行计算。
武器购买
题面描述
商店里有n个武器,第i个武器的强度为pi。花费为ci。
小杨想要购买一些武器,满足这些武器的总强度不小于P,总花费不超过Q,小杨想知道是否满足条件的购买方案,如果有,最少花费又是多少。
输入格式
第一行包含一个正整数t,代表测试数据组数。
对于每组测试数据,第一行包含三个正整数n,P,Q,含义如题面所示。
之后n行,每行包含两个正整数pi,ci,代表武器的强度和花费。
输出格式
对于每组测试数据,如果存在满足条件的购买方案,输出最少花费,否则输出-1。
样例
燃烧
小杨有一颗包含n个节点的树,其中节点的编号从1到n。节点i的权值为ai。
小杨可以选择一个初始节点引燃,每个燃烧的节点会将其相邻节点中权值严格小于自身权值的节点也引燃,火焰会在节点间扩散直到不会有新的节点被引燃。
小杨想知道在合理选择初始节点的情况下,最多可以燃烧多少个节点。
第一行包含一个正整数 n,代表节点数量。
第二行包含 n个正整数 a1,a2,..,an,代表节点权值。
之后 n行,每行包含两个正整数ui,vi ,代表存在一条连接节点ui 和vi 的边。
输出一个正整数,代表最多燃烧的节点个数。