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_back
typedef 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]);}
}

HDU 5411 CRB and Puzzle (2015年多校比赛第10场)相关推荐

  1. HDU - 5411 CRB and Puzzle 矩阵快速幂

    HDU - 5411 考虑直接dp会T, 用矩阵优化一下就好了. #include<bits/stdc++.h> #define LL long long #define LD long ...

  2. hdu 5411 CRB and Puzzle(矩阵快速幂)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5411 解题思路: 题目大意: 给定n个点 常数m 下面n行第i行第一个数字表示i点的出边数,后面给出 ...

  3. hdu 5411 CRB and Puzzle 矩阵高速幂

    链接 题解链接:http://www.cygmasot.com/index.php/2015/08/20/hdu_5411/ 给定n个点 常数m 以下n行第i行第一个数字表示i点的出边数.后面给出这些 ...

  4. hdu 5411 CRB and Puzzle

    Sample Input 1 3 2 1 2 1 3 0 Sample Output 6 Hint possible patterns are ∅, 1, 2, 3, 1→2, 2→3 解释样例: 第 ...

  5. 【矩阵快速幂】 HDU 5411 CRB and Puzzle 等比

    点击打开链接 题意显然是 求 A+A^2+A^3+....+A^m 这就是经典题目 矩阵乘法十种经典题目 递归解决 后半部分提取 A^(m/2) 该题再特判下 m==1的时候 #include < ...

  6. HDU 5384 Danganronpa (2015年多校比赛第8场)

    1.题目描写叙述:点击打开链接 2.解题思路:本题利用字典树解决.本题要求查找全部的B[j]在A[i]中出现的总次数.那么我们能够建立一颗字典树,将全部的B[j]插入字典树,因为一个串的全部字串相当于 ...

  7. HDOJ 5411 CRB and Puzzle 矩阵高速幂

    直接构造矩阵,最上面一行加一排1.高速幂计算矩阵的m次方,统计第一行的和 CRB and Puzzle Time Limit: 2000/1000 MS (Java/Others)    Memory ...

  8. HDU 4893 Wow! Such Sequence!(2014年多校联合 第三场 G)(线段树)

    磨了一天的线段树,不能说完全搞清楚,只能说有一个大概的了解,靠着模板才把这道题A了,只能说太弱~~! 题意: 初始时有一字符串,全为0. 三种操作: 1 k d - add  把d加到第k个数上去 2 ...

  9. 三校生计算机模拟试题1,甘肃省2015年“三校生”考试摸拟试题1

    2015年甘肃省"三校生"计算机应用高考模拟试题,命题组试题,命中率极高,冲刺高考专用考题! 甘肃省2015年"三校生"考试摸拟试题 (计算机应用基础) 班级 ...

最新文章

  1. 精华自取:神策 2019 数据驱动大会亮点回顾
  2. 原:开辟内存时,可以以结构体为单位,这样测试,是对的吧?
  3. busybox 安装mysql_安装busybox
  4. leetcode 509. 斐波那契数
  5. 【mysql】Innodb三大特性之double write
  6. 三点估算pmp_【每日一练】PMP项目管理专业资格认证考试练习题(十)
  7. jsp标记之动作标记介绍
  8. pythonqt项目_python GUI编程 QT5开发项目实战
  9. Spring-context-ApplicationContextInitializer接口TODO
  10. linux 将当前时间往后调整2分钟_Python处理时间序列常用方法汇总
  11. 面向项目(九)—— 交叉工具链
  12. 分享CodeIgniter上传图片成功的全过程
  13. python使用numpy按一定格式读取bin文件
  14. 现在学 Prolog 递归
  15. 带协议解析的串口调试助手
  16. hadoop完全分布式教程网页
  17. Angular学习笔记——自定义指令directive参数详解
  18. 【NLP】ESPNet语音识别——原理、实现过程
  19. 京东云申元庆:用创新技术改变中国,顺道改变世界
  20. python——实现鼠标与键盘监听与事件处理

热门文章

  1. 看一名 KDE 开发者如何使用 C++17 为项目提升巨大速度
  2. 7月17日云栖精选夜读:深度 | 两个案例,掌握AI在大数据领域的前沿应用
  3. ajax请求,请求头是provisional are shown。请求未发送出去
  4. 开源 java CMS - FreeCMS2.3 会员组管理
  5. 解决Chrome浏览器打开虾米音乐网页播放器时的排版问题
  6. 卡方 matlab,matlab卡方分布 卡方检验(Chi-square test)及其MATLAB实现 - 余姚娱乐网
  7. ajax 导出文件给 文件重新命名_Tanner LEdit 05 | 导出GDSII文件
  8. 互联网协议 — LISP 位置/身份分离协议
  9. NanoPi NEO Air使用十五:使用V4L2驱动USB摄像头
  10. KEIL MDK LIB库文件的制作