HDU 5411 CRB and Puzzle (2015年多校比赛第10场)
来源:互联网 发布:伟哥影响生育吗 知乎 编辑:程序博客网 时间:2024/05/16 08:27
1.题目描述:点击打开链接
2.解题思路:本题实际是是已知一张无向图,问长度小于等于m的路径一共有多少条。可以通过建立转移矩阵利用矩阵快速幂解决。其中,转移矩阵就是输入时候的邻接矩阵,同时多增加最后一列,都置为1,表示从i开始的,长度不超过M的路径的答案总数(最后一行的1~n列为全0行,可以理解为空集),那么把转移矩阵自乘M-1次后就是路径长度为M的转移矩阵(这里的路径长度指的是顶点的个数,顶点=边数+1,因此只需要乘M-1次)。为何便于求和,可以设置一个第一行都为1的矩阵B,B*Trans后B[1][n+1]就是A的第n+1列所有项的和。输出即可。
3.代码:
#define _CRT_SECURE_NO_WARNINGS#include<iostream>#include<algorithm>#include<cassert>#include<string>#include<sstream>#include<set>#include<vector>#include<stack>#include<map>#include<queue>#include<deque>#include<cstdlib>#include<cstdio>#include<cstring>#include<cmath>#include<ctime>#include<cctype>#include<functional>using namespace std;#define me(s) memset(s,0,sizeof(s))#define pb push_backtypedef long long ll;typedef unsigned int uint;typedef unsigned long long ull;typedef pair <ll, int> P;const int MOD = 2015;const int N = 100000 + 5;const int sz = 55;struct Matrix{int m[sz][sz];Matrix(){ me(m); }Matrix operator*(const Matrix&b){Matrix c;for (int i = 0; i<sz; i++)for (int j = 0; j<sz; j++)for (int k = 0; k<sz; k++)c.m[i][j] = (c.m[i][j] + m[i][k] * b.m[k][j]) % MOD;return c;}Matrix get(int n){Matrix res, b = *this;for (int i = 0; i<sz; i++)res.m[i][i] = 1;while (n>0){if (n & 1)res = res*b;b = b*b;n >>= 1;}return res;}};int main(){int T;for (scanf("%d", &T); T--;){Matrix a, b;int m, n, cnt, x;scanf("%d%d", &n, &m);for (int i = 1; i <= n + 1; i++)a.m[i][n + 1] = 1; //第n+1列都设置为1,便于求和for (int i = 1; i <= n; i++){scanf("%d", &cnt);for (int j = 1; j <= cnt; j++){scanf("%d", &x);a.m[i][x] = 1;}}for (int i = 1; i <= n + 1; i++)//b矩阵第1行全部为1,便于对a矩阵的第n+1列求和b.m[1][i] = 1;a = a.get(m);b = b*a;if (m == 1)printf("%d\n", n + 1);else printf("%d\n", b.m[1][n + 1]);}}
0 0
- HDU 5411 CRB and Puzzle (2015年多校比赛第10场)
- HDU 5414 CRB and String (2015年多校比赛第10场)
- HDU 5410 CRB and His Birthday (2015年多校比赛第10场)
- HDU 5407 CRB and Candies (2015年多校比赛第10场)
- HDU 5411 CRB and Puzzle
- hdu 5411 CRB and Puzzle
- HDU 5416 CRB and Tree (2015多校第10场)
- hdu 5411 CRB and Puzzle(矩阵快速幂)
- hdu 5411 CRB and Puzzle(矩阵快速幂)
- HDU 5411 CRB and puzzle (Dp + 矩阵快速幂)
- hdu 5411 CRB and Puzzle(矩阵快速幂)
- 矩阵快速幂(CRB and Puzzle,HDU 5411)
- hdu 5411 CRB and Puzzle 2015 多校联合训练赛#10 快速矩阵幂
- HDU 5360 Hiking (2015年多校比赛第6场)
- HDU 5353 Average (2015年多校比赛第6场)
- HDU 5374 Tetris (2015年多校比赛第7场)
- HDU 5384 Danganronpa (2015年多校比赛第8场)
- HDU 5386 Cover (2015年多校比赛第8场)
- java.sql.SQLException: Access denied for user 'root'@'gy-pc' (using password: YES)
- android studio导入so库Failure [INSTALL_FAILED_NO_MATCHING_ABIS]解决方案
- 81 css ie8无法识别背景图片
- Jfinal使用Freemarker配置处理NULL、重起生效等问题
- 2015年至关重要的网页版式设计趋势
- HDU 5411 CRB and Puzzle (2015年多校比赛第10场)
- HDOJ 1869 六度分离(最短路之floyd)
- [LeetCode257] Binary Tree Paths
- 【c++版数据结构】之单链表的实现(带头结点以及尾节点)
- WEB测试总结
- UVA 540 Team Queue
- 一点一点学习struts1(一)_简介
- 黑马程序员-----Java基础-----Map
- hdu5414(2015多校10)--CRB and String(字符串匹配)