HDU2157 How many ways??---(邻接矩阵,图论,矩阵快速幂)
http://acm.hdu.edu.cn/showproblem.php?pid=2157
How many ways??
Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 3013    Accepted Submission(s): 1154
接下来的T行, 每行有三个整数 A, B, k, 表示问你从A 点到 B点恰好经过k个点的方案数 (k < 20), 可以走重复边。如果不存在这样的走法, 则输出0
当n, m都为0的时候输入结束
4 4
0 1
0 2
1 3
2 3
2
0 3 2
0 3 3
3 6
0 1
1 0
0 2
2 0
1 2
2 1
2
1 2 1
0 1 3
0 0
Sample Output
2
0
1
3
分析:
图论中,求两点(e.g. u,v)间长度为k的路径条数,可通过,求邻接矩阵的k次幂,对应找出A[u][v]值即可
问题转化求矩阵的快速幂!
#include "cstdio"
#include "cstring"
///矩阵模型
struct matrix{
int a[][];
void init(int n)
{
for(int i=;i<n;i++)
memset(a[i],,sizeof(a[i]));
}
}s,w; ///两矩阵相乘
matrix mul(matrix x,matrix y,int n)
{
matrix c;
c.init(n);
for(int i=;i<n;i++)
{
for(int j=;j<n;j++)
{
for(int k=;k<n;k++)
{
c.a[i][j]+=x.a[i][k]*y.a[k][j];
}
c.a[i][j] %= ;
}
}
return c;
} ///快速幂
matrix fastPow(matrix x,int k,int n)///x不要加引用
{
matrix c;
c.init(n);
for(int i=;i<n;i++)///E
c.a[i][i]=;
while(k>)
{
if(k&)
c=mul(c,x,n);///注意顺序
x=mul(x,x,n);
k>>=;
}
return c;
} int main()
{
int n,m,t;
while(~scanf("%d%d",&n,&m)&&n+m)
{
s.init(n);
int x,y,k,a,b;
for(int i=;i<m;i++)
{
scanf("%d%d",&x,&y);
s.a[x][y]=;///有向图
}
scanf("%d",&t);
for(int i=;i<t;i++)
{
scanf("%d%d%d",&a,&b,&k);
w=fastPow(s,k,n);
printf("%d\n",w.a[a][b]);
}
}
return ;
}
HDU2157 How many ways??---(邻接矩阵,图论,矩阵快速幂)的更多相关文章
- How many ways?? HDU - 2157 矩阵快速幂
		题目描述 春天到了, HDU校园里开满了花, 姹紫嫣红, 非常美丽. 葱头是个爱花的人, 看着校花校草竞相开放, 漫步校园, 心情也变得舒畅. 为了多看看这迷人的校园, 葱头决定, 每次上课都走不同的 ... 
- HDU 2157 How many ways?? 临接矩阵+快速幂
		Problem Description 春天到了, HDU校园里开满了花, 姹紫嫣红, 非常美丽. 葱头是个爱花的人, 看着校花校草竞相开放, 漫步校园, 心情也变得舒畅. 为了多看看这迷人的校园, ... 
- 【BZOJ】1875: [SDOI2009]HH去散步 矩阵快速幂
		[题意]给定n个点m边的无向图,求A到B恰好经过t条边的路径数,路径须满足每条边都和前一条边不同.n<=20,m<=60,t<=2^30. [算法]矩阵快速幂 [题解]将图的邻接矩阵 ... 
- hdu2157之矩阵快速幂
		How many ways?? Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ... 
- Luogu 3758 [TJOI2017]可乐(有向图邻接矩阵幂的意义 矩阵快速幂)
		题目描述 加里敦星球的人们特别喜欢喝可乐.因而,他们的敌对星球研发出了一个可乐机器人,并且放在了加里敦星球的1号城市上.这个可乐机器人有三种行为: 停在原地,去下一个相邻的城市,自爆.它每一秒都会随机 ... 
- HDU 2157 How many ways??(简单线性DP | | 矩阵快速幂)
		题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=2157 这道题目很多人的题解都是矩阵快速幂写的,矩阵快速幂倒是麻烦了许多了.先给DP的方法 dp[i][ ... 
- POJ2778 DNA Sequence(AC自动机+矩阵快速幂)
		题目给m个病毒串,问不包含病毒串的长度n的DNA片段有几个. 感觉这题好神,看了好久的题解. 所有病毒串构造一个AC自动机,这个AC自动机可以看作一张有向图,图上的每个顶点就是Trie树上的结点,每个 ... 
- POJ 2778 DNA Sequence(AC自动机 + 矩阵快速幂)题解
		题意:给出m个模式串,要求你构造长度为n(n <= 2000000000)的主串,主串不包含模式串,问这样的主串有几个 思路:因为要不包含模式串,显然又是ac自动机.因为n很大,所以用dp不太好 ... 
- 【66测试20161115】【树】【DP_LIS】【SPFA】【同余最短路】【递推】【矩阵快速幂】
		还有3天,今天考试又崩了.状态还没有调整过来... 第一题:小L的二叉树 勤奋又善于思考的小L接触了信息学竞赛,开始的学习十分顺利.但是,小L对数据结构的掌握实在十分渣渣.所以,小L当时卡在了二叉树. ... 
- poj 3613 经过k条边最短路 floyd+矩阵快速幂
		http://poj.org/problem?id=3613 s->t上经过k条边的最短路 先把1000范围的点离散化到200中,然后使用最短路可以使用floyd,由于求的是经过k条路的最短路, ... 
随机推荐
- win10 无法修改默认程序 默认打开方式的解决方法
			此时是2018年11月24日 win10 pro 64位 版本是1803 具体版本号是17134 情景: 我的状况是.json文件的默认打开方式被新安装的应用霸占了,然后无论是通过“右键-属性-更改 ... 
- JMeter学习笔记(九) 参数化4--User Variables
			4.User Variables 用户参数 1)线程组右键添加 -> 前置处理器 -> 用户参数 2)配置用户参数 3)添加HTTP请求,引用用户参数,格式: ${} 4)配置线程数 5) ... 
- Leetcode 55. Jump Game & 45. Jump Game II
			55. Jump Game Description Given an array of non-negative integers, you are initially positioned at t ... 
- Git的使用和部署
			Git是什么? Git是目前世界上最先进的分布式版本控制系统(没有之一). 什么是版本控制系统? 没有版本控制系统 有了版本控制系统 版本 文件名 用户 说明 日期 1 service.doc 张三 ... 
- Failed loading D:\Program Files\phpStudy20161103\php\php-5.6.27-nts\ext\php_xdebug.dll
			我用的是phpstudy 更新完composer php 切换composer的国内源的时候老是报找不到\php_xdebug.dll的错误, 原因是, 在php.ini 里面默写就是在Program ... 
- Linux 简单socket实现UDP通信
			服务器端 #include <stdio.h> #include <stdlib.h> #include <sys/types.h> #include <sy ... 
- Mac下安装OpenCV问题
			最近看了纹理特征方面的paper,看了一些资料之后,想要实际动手实现一下其中LBP算法,果然OpenCV中已经实现. 问题 No module named "cv2" 当我在我们项 ... 
- iOS-UIImageView播放动画
			NSArray *gifArray = [NSArray arrayWithObjects:[UIImage imageNamed:@"lanya1"],[UIImage imag ... 
- PAT 1089 狼人杀-简单版
			https://pintia.cn/problem-sets/994805260223102976/problems/1038429385296453632 以下文字摘自<灵机一动·好玩的数学& ... 
- PAT 1015 德才论
			https://pintia.cn/problem-sets/994805260223102976/problems/994805307551629312 宋代史学家司马光在<资治通鉴>中 ... 
