首页 > 代码库 > Codeforces Round #403(div 2)

Codeforces Round #403(div 2)

A

=w=

B

题意:一个数轴上有n个整点,每个点都有一个速度,选一个点让他们集合,使得时间最少。

分析:

   直接三分

C

题意:给定一棵树,任意两个距离小等于二的点不能染相同的颜色,求最小颜色数和染色方案。 n<=2*10^5

分析:

   容易知道答案就是最大的度数+1

   至于方案直接暴搜出方案就行

D

题意:有n个足球队,每个队有两个选名字的方案,也就是直接给定了两个名字。所有球队不能有相同的名字。特殊的,如果有两个球队第一个名字相同,一个球队选了第二个名字,另一个球队不能选第一个名字。n<=1000

分析:模拟

   按照第一名字为关键字,那些第一名字相同的队伍都只能取第二名字

   对于剩下的集合,考虑那些只能选一个名字的,选择它,并更新当前已选名字

   这样剩余未定集合会越来越小,直至没有

   在这过程中,若有一只队伍两个名字都被占用,那么说明不合法

E

题意:给定一个n个点m条边的连通图,然后你要用k条路径覆盖所有的点,每条路径最多2*n/k向上取整个点,求一个方案。n<=2*10^5

分析:构造

   把其弄成一个树,然后dfs序,会有2*n-1个点,那么每次只需要走2*n/k个点就行了,注意最后可能有剩余走的机会,不能不走,随便走个点

F

题意:给丁一个n点m边的图,然后每条边有一个类别1或者0。

   你要按照给定的顺序走边:一条0的,然后把刚走的取反接起来,然后一直做。比如P代表0,B代表1,那么你要这么走:

   P, PB, PBBP, PBBPBPPB, PBBPBPPBBPPBPBBP, and so on.

   求从1开始最多能走多少条。如果答案>10^18,输出-1   n<=500

分析:bitset+倍增

   还是很吼的思路

   如果只考虑走2的次方步,那么应该是可以倍增出结果的

   对于一般情况,一定是由几个2的次幂构成的,这说明也可以dp求解!

   而且上面两种情况都有一种特点,那就是对于一条路径上的两段不同次幂路,开头一定是不同的,开头一定是0 1 0 1 0 1这种!

   f[i][j][0/1]表示当次幂边的长度<=2^j时候,以i点为起点,0/1为第一条边,能走的最远路

   那么有转移f[i][j][0/1]=max(f[k][j-1][0/1 xor 1]+(1<<j)) (其中i走2^j步可以走到k)

   这个转移的关键就是如何快速知道符合的k,那么很显然要预处理

   很容易想到g[i][j][0/1][k],表示从i点开始,以0/1边为起点,走2^j步,能否走到k点

   至于转移的话,需要枚举一个j-1层的中间点,作为i->j的转移,这样时间复杂度是O(n^3*60)会TLE

   这里就要用到bitset

   bitset<n> g[i][j][0/1] 就表示从i点开始,以0/1边为起点,走2^j步,能到达其他点的情况(1表示可以到达)

   转移的时候就是bitset的或操作,因为是位运算,所以很快

Codeforces Round #403(div 2)