摘要: 这道题题意是,给定一棵树,每条边都有一定的权值,q次询问,每次询问某两点间的距离。这样就可以用LCA来解,首先找到u, v 两点的lca,然后计算一下距离值就可以了。这里的计算方法是,记下根结点到任意一点的距离dis[],这样ans = dis[u] + dis[v] - 2 * dis[lca(v, v)]了,这个表达式还是比较容易理解的。。离线复杂度:O(n+m)在线复杂度:O(nlgn+mlgn)显然离线的算法有优势!!!!!!!!(在线算法的思想很好)法一(离线法):LCA Tarjan算法--模版:http://www.cnblogs.com/sbaof/articles/33389 阅读全文
posted @ 2013-09-24 21:49 baoff 阅读(241) 评论(0) 推荐(0) 编辑
摘要: 题意:给n*m的地图,在地图的点上走,(n+1)*(m+1)个点,两种操作:往下走D和往右走R。现在要从左上角走到右下角,给定两个操作串,问包含这两个串的走法总共有多少种。做法:用这两个串构建自动机,然后只要在自动机上走n+m+1步就好了。就像一个递推,dp[x][y][i][cur]表示在i状态到达x,y坐标时走过的串的状态为cur时的总方案数//#pragma comment(linker, "/STACK:102400000")#include#include#include#include#include#include#include#include#includ 阅读全文
posted @ 2013-09-24 12:02 baoff 阅读(190) 评论(0) 推荐(0) 编辑
摘要: 题意:一个数列,给出这个数列中的某些位置的数,给出所有相邻的三个数字的和,数列头和尾处给出相邻两个数字的和。有若干次询问,每次问某一位置的数字的最大值。分析:设数列为a1~an。首先通过相邻三个数字的和我们可以求出a3,a6,a9……是多少。a3=sum(a1,a2,a3)-sum(a1,a2)。a6=sum(a4,a5,a6)-sum(a3,a4,a5)。后面依次类推。推到了数列的最右面,如果恰好知道了an或者a(n-1)中的一个,那么可以通过sum(an,a(n-1))减去它来求得另一个。这个题还有个性质就是,只要知道数列中连续的两位就可以通过不断向两侧延伸的方法得到整个数列。因为任意相邻 阅读全文
posted @ 2013-09-24 10:02 baoff 阅读(139) 评论(0) 推荐(0) 编辑