[HNOI2019]校园旅行(bfs) 题面 洛谷 题解 首先考虑暴力做法怎么做. 把所有可行的二元组全部丢进队列里,每次两个点分别向两侧拓展一个同色点,然后更新可行的情况. 这样子的复杂度是\(O(m^2)\)的. 考虑如何优化边数,先说结论: 首先对于一个同色联通块,如果它是一个二分图,那么只需要保留一棵生成树就行了,否则随便找个点连一条自环. 对于连接不同色两个点的边,一定构成一个二分图,只需要保留一棵生成树就行了. 证明是这样子的: 首先我们把路径划分成若干个同色连续段,那么我们要做的就…