摘要:
法1——图论: 其实图论并不是我一开始就想出来的。。。纯粹是先受了网络流做法的启发改进的。对于每个士兵都要守护一行或者一列,将守护行看做标号$i$的点,连向所在的列$y+n$(注意平移),守护列则反过来。这样,这张图上每个点都有一个出边,这就是一片基环树森林。但是要注意的是,同一条边的两个方向不能同 阅读全文
摘要:
简化题意:一序列,查询区间和$s_{i\sim j}$已知花费$c_{i,j}$,求知悉所有数最小花费。 神仙思路题 查询一个区间$i\sim j$,记前缀和$sum$,则如果在某时候知道了$sum_{i-1}$或者$sum_j$中的任意一个,另一个也可以知道,那么可以选择花费$c_{i,j}$连无 阅读全文
摘要:
显然分析可知这个图最后连起来是一个森林,每棵树有一个根再算一个代价。那么这些跟需要连向某一点一个建立水库的代价,且根可以有多个但不能没有,则考虑用超级源点0向所有点连虚边,Prim跑MST即可保证有至少一个根。 1 #include<iostream> 2 #include<cstdio> 3 #i 阅读全文