1.题目描述:点击打开链接
2.解题思路:本题利用矩阵快速幂+概率dp解决。根据题意可以画出来一个状态转移图,根据状态转移图不难得到一步转移概率矩阵,接下来的问题是:如何求解d步之内(包括d)均无法从其他点走到结点u的概率。
首先,既然无法到达结点u,那么出发的时候就不能选择该点。其次,为了使其他结点也无法到达结点u,可以将一步转移概率矩阵中跟结点u有关的概率全部置零。即表示u结点出发无法到达其他结点,其他结点也均无法到达u结点,这样就相当于把u结点从状态转移图中暂时删去了。然后根据马氏链的知识,假设一步转移概率矩阵为A,那么d步转移概率矩阵为A^d。再考虑到选择出发点也构成一个矩阵B,那么最终d步时候的概率矩阵为B=B*(A^d)。最终得到的B矩阵中的B[i][j]即为i经过d步走到j的概率。
这里有一个小技巧,为了便于计算B矩阵,可以在初始化的时候只将第0行的每个结点都置为1/n(结点i仍然置零),表示结点j被选为出发点的概率,这样,最终计算出的B矩阵也只在第0行有结果,表示其他点到达结点j的概率,最后,只需要把这些概率求和,即可得到到达除结点i之外其他结点的概率,即不到达结点i的概率。
本题的时间复杂度为O(N^4logd)。
3.代码&#x