1297: [SCOI2009]迷路


Time Limit: 10 Sec  Memory Limit: 162 MB
Submit: 1385  Solved: 993
[Submit][Status][Discuss]

Description


windy在有向图中迷路了。 该有向图有 N 个节点,windy从节点 0 出发,他必须恰好在 T 时刻到达节点 N-1。 现在给出该有向图,你能告诉windy总共有多少种不同的路径吗? 注意:windy不能在某个节点逗留,且通过某有向边的时间严格为给定的时间。

Input


第一行包含两个整数,N T。 接下来有 N 行,每行一个长度为 N 的字符串。 第i行第j列为'0'表示从节点i到节点j没有边。 为'1'到'9'表示从节点i到节点j需要耗费的时间。

Output


包含一个整数,可能的路径数,这个数可能很大,只需输出这个数除以2009的余数。

Sample Input


【输入样例一】



【输入样例二】


Sample Output


【输出样例一】



【样例解释一】

->->


【输出样例二】



HINT


30%的数据,满足 2 <= N <= 5 ; 1 <= T <= 30 。 100%的数据,满足 2 <= N <= 10 ; 1 <= T <= 1000000000 。

分析:


  先用dp的思想分析可以分析出转移方程dp[i][t] = ∑dp[j][t  -  time(i,j)];但是t太大,并且时间也不允许;

  想了一下发现转移方程是固定的,可以很自然联想矩阵乘法 + 快速幂。
  但是写的时候出现困难了,发现每个点对间有些彼此到达时间各不相同不好处理。于是就困住了

正解:


 

可以把一个点拆出9个虚拟结点出来,node[i][j] 向 node[i][j + ]点向虚拟结点连边为1,然后所有到达这个点的都连边向node[i][],所有以这个点出发能到距离为j的点q从node[i][j - ]连边1向node[q][];

于是原图换成了一个10 * 10的矩阵,矩乘 + 快速幂求出即行。

复杂度还是很低的。

矩阵乘法:


其实关于dp的东西如果发现是固定转移并且是刷表什么的,都可以联想到转换成矩乘来做。

AC代码:


# include <iostream>
# include <cstdio>
# include <cstring>
using namespace std;
const int mod = ;
int n;
long long t;
struct fi{
int data[][];
fi(){memset(data,,sizeof(data));
}
}A,T;
inline fi operator * (fi & a,fi & b){
fi t;
for(int i = ;i < n * ;i++){
for(int j = ;j < n * ;j++){
t.data[i][j] = ;
for(int k = ;k < n * ;k++){
t.data[i][j] += a.data[i][k] * b.data[k][j];
}
if(t.data[i][j] >= mod)t.data[i][j] %= mod;
}
}
return t;
}
inline fi operator +(fi & a,fi & b){
fi t;
for(int i = ;i < n * ;i++){
for(int j = ;j < n * ;j++){
t.data[i][j] = a.data[i][j] + b.data[i][j];
if(t.data[i][j] >= mod)t.data[i][j] %= mod;
}
}
return t;
}
inline void cmd(fi & A,fi & T,long long k){
while(k){
if(k & 1LL)A = A * T;
T = T * T;
k >>= 1LL;
}
return;
}
char str[];
void build(){
scanf("%d %lld",&n,&t);
int x;
for(int i = ;i < n;i++){
scanf("%s",str);
for(int j = ;j < n;j++){
x = str[j] - '';
if(!x)continue;
x -= ;
T.data[i * + x][j * ] = ;
}
for(int j = ;j < ;j++){
T.data[i * + j][i * + j + ] = ;
}
}
A.data[][] = ;
cmd(A,T,t);
printf("%d\n",A.data[][(n - ) * ]);
}
int main(){
build();
}

[Bzoj1297][Scoi2009 ]迷路 (矩阵乘法 + 拆点)的更多相关文章

  1. bzoj1297: [SCOI2009]迷路(矩阵乘法+拆点)

    题目大意:有向图里10个点,点与点之间距离不超过9,问从1刚好走过T距离到达n的方案数. 当时看到这题就想到了某道奶牛题(戳我).这两道题的区别就是奶牛题问的是走T条边,这道题是每条边都有一个边权求走 ...

  2. BZOJ1297 [SCOI2009]迷路 矩阵乘法

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1297 题意概括 有向图有 N 个节点,从节点 0 出发,他必须恰好在 T 时刻到达节点 N-1. ...

  3. 【bzoj1297】[SCOI2009]迷路 矩阵乘法

    题目描述 给出一个 $n$ 个点的有向图,每条边的权值都在 $[1,9]$ 之间.给出 $t$ ,求从 $1$ 到 $n$ ,经过路径边权和恰好为 $t$ 的方案数模2009. 输入 第一行包含两个整 ...

  4. [luogu4159 SCOI2009] 迷路(矩阵乘法)

    传送门 Solution 矩阵乘法新姿势qwq 我们知道当边权为1是我们可以利用矩阵快速幂来方便的求出路径数 那么对于边权很小的时候,我们可以将每个点都拆成若干个点 然后就将边权不为1转化为边权为1了 ...

  5. LUOGU P4159 [SCOI2009]迷路(矩阵乘法)

    传送门 解题思路 以前bpw讲过的一道题,顺便复习一下矩阵乘法.做法就是拆点,把每个点拆成\(9\)个点,然后挨个连边.之后若\(i\)与\(j\)之间的边长度为\(x\),就让\(i\)的第\(x\ ...

  6. BZOJ1297: [SCOI2009]迷路 矩阵快速幂

    Description windy在有向图中迷路了. 该有向图有 N 个节点,windy从节点 0 出发,他必须恰好在 T 时刻到达节点 N-1. 现在给出该有向图,你能告诉windy总共有多少种不同 ...

  7. 【矩阵快速幂】bzoj1297 [SCOI2009]迷路

    1297: [SCOI2009]迷路 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1407  Solved: 1007[Submit][Status ...

  8. [SCOI2009]迷路(矩阵快速幂) 题解

    Description windy在有向图中迷路了. 该有向图有 N 个节点,windy从节点 0 出发,他必须恰好在 T 时刻到达节点 N-1. 现在给出该有向图,你能告诉windy总共有多少种不同 ...

  9. bzoj1297 [SCOI2009]迷路——拆点+矩阵快速幂

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1297 一看感觉是矩阵快速幂之类的,但边权不好处理啊: 普通的矩阵快速幂只能处理边权为1的,所 ...

随机推荐

  1. ios水果风暴游戏源码项目下载

    这是一款ios水果风暴游戏源码下载,介绍给大家一下,喜欢的朋友可以下载学习一下吧.应用介绍:这是一个以获得高分和挑战更高难度为目的的游戏.游戏中有九种不同的卡通水果,您可以交换屏幕中两个相邻水果的位置 ...

  2. 30行代码消费腾讯人工智能开放平台提供的自然语言处理API

    腾讯人工智能AI开放平台上提供了很多免费的人工智能API,开发人员只需要一个QQ号就可以登录进去使用. 腾讯人工智能AI开放平台的地址:https://ai.qq.com/ 里面的好东西很多,以自然语 ...

  3. mybatis+oracle 完成插入数据库,并将主键返回的注意事项

    mybatis+oracle 完成插入数据库,并将主键返回的注意事项一条插入语句就踩了不少的坑,首先我的建表语句是: create table t_openapi_batch_info( BATCH_ ...

  4. RSA2

    进行签名的加密 package com.goboosoft.common.pay.util; import java.io.ByteArrayInputStream; import java.io.I ...

  5. Python3简明教程(十四)—— Collections模块

    collections 是 Python 内建的一个集合模块,提供了许多有用的集合类. 在这个实验我们会学习 Collections 模块.这个模块实现了一些很好的数据结构,它们能帮助你解决各种实际问 ...

  6. this.treeData = JSON.parse(JSON.stringify(this.d)) 树的序列化反序列化

    this.treeData = JSON.parse(JSON.stringify(this.d))

  7. Java数据结构和算法(二)--队列

    上一篇文章写了栈的相关知识,而本文会讲一下队列 队列是一种特殊的线性表,在尾部插入(入队Enqueue),从头部删除(出队Dequeue),和栈的特性相反,存取数据特点是:FIFO Java中queu ...

  8. MySQL-03 SQL语句设计

    学习要点 SQL语句分类 DML语句 DML 查询语句 SQL语句分类 数据操纵语言(DML):用来操纵数据库中数据的命令.包括:SELECT.INSERT.UPDATE.DELETE. 数据定义语言 ...

  9. 前端打包--source-map=false作用

    参考:http://www.cnblogs.com/axl234/p/6500534.htmlng serve默认会产生.map文件,该文件保存有原始代码与运行代码的映射关系, 浏览器可以通过它找到原 ...

  10. Map与对象关系的思考之P1563玩具谜题

    P1563 玩具谜题 结论: map在一些情况有种"对象"的意味,在JSON中,对象可以用K-V格式存储:mybatis中参数是map或者对象都可以实现解析...k-v格式的数据存 ...