0/1背包第K优解。我用了一个蠢方法
|
|
为什么O(n^2)的算法也可以过。。。。不科学
|
|
题目 988 环保绿化
2014-08-23 09:51:18
|
|
费马小定理+快速幂?
|
|
就是C(k-1,g(x)-1)。。马克之
题目 604 方程
2014-08-22 21:35:17
|
|
尼玛%d打成%D导致WA3次
本地测试又没有问题。。幸好不是考试 |
|
Pascal同学请注意,当进行乘法运算时,得出的积会暂时存储在第一个出现的变量当中!所以有可能会爆215(值溢出)!所以先用一个能存的下的数做第一个是十分重要的- -
|
|
尼玛如果dist[i][k]+dist[k][j]==dist[i][j],那么way[i][j]要变成way[i][k]*way[k][j]
之前一直直接变成1了。。 WA无数遍,还是不够熟悉啊 |
|
题目 1048 [Citric S2] 一道防AK好题
2014-08-22 10:14:42
|
|
手残党刷了一个夏天才刷完- -
|
|
我来组成分块……
|
|
单调队列= =一开始加入写错了
设当前正在处理第K位,则向单调队列中加入f[i-l],并删除单调队列中在i-r之前的数字 好像只能分析K点从哪里来,不能用从哪个点可以到K 即只能用f[k]=Max{f[k-i]+cold[k]}i∈[l,r] 反正做对了~\(≧▽≦)/~ |
|
|
|
貌似裸判断的实际复杂度比O(mn)好的多得多……
|
|
区间贪心
|
|
为了艾尔
题目 1179 [郑州101中学] 圣战
2014-08-20 11:25:52
|
|
最简单的方法,预处理成01背包
|
|
BFS+dp
|
|
拓扑排序版
|
|
先用Floyd找到直径,由于这是一棵无根树,树中两点最短距离最大的就是直径的两个端点
或者从任意点v为根找到v点距离最大的点u 然后以u为直径的一个端点找距离u最大的点f为直径的另一个端点 然后就是枚举路径长度取最小值 |