HDU 2254 奧運(數論+矩陣)
題目中文的不解釋啊。。。
需要注意的就是:離散數學中,有向圖的鄰接矩陣A表示所有點之間路徑長度為1的路徑數量,A^n則表示路徑長度為n的路徑數量,故需要求某兩點在(A^t1)~(A^t2)的路徑數量之和。
奧運
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submission(s): 2251 Accepted Submission(s): 572
Problem Description
北京迎來了第一個奧運會,我們的歡呼聲響徹中國大地,所以今年的奧運金牌 day day up!
比爾蓋茲坐上鳥巢裡,手裡搖著小紙扇,看的不亦樂乎,被俺們健兒的頑強拼搏的精神深深的感動了。反正我的錢也多的沒地方放了,他對自己說,我自己也來舉辦一個奧運會,看誰的更火。不過他的奧運會很特別:
1 參加人員必須是中國人;
2 至少會加法運算(因為要計算本人獲得的金牌數)
他知道中國有很多的名勝古蹟,他知道自己在t1 到 t2天內不可能把所有的地方都玩遍,所以他決定指定兩個地方v1,v2,如果參賽員能計算出在t1到t2天(包括t1,t2)內從v1到v2共有多少種走法(每條道路走需要花一天的時間,且不能在某個城市停留,且t1=0時的走法數為0),那麼他就會獲得相應數量的金牌,城市的總數<=30,兩個城市間可以有多條道路
,每條都視為是不同的。
比爾蓋茲坐上鳥巢裡,手裡搖著小紙扇,看的不亦樂乎,被俺們健兒的頑強拼搏的精神深深的感動了。反正我的錢也多的沒地方放了,他對自己說,我自己也來舉辦一個奧運會,看誰的更火。不過他的奧運會很特別:
1 參加人員必須是中國人;
2 至少會加法運算(因為要計算本人獲得的金牌數)
他知道中國有很多的名勝古蹟,他知道自己在t1 到 t2天內不可能把所有的地方都玩遍,所以他決定指定兩個地方v1,v2,如果參賽員能計算出在t1到t2天(包括t1,t2)內從v1到v2共有多少種走法(每條道路走需要花一天的時間,且不能在某個城市停留,且t1=0時的走法數為0),那麼他就會獲得相應數量的金牌,城市的總數<=30,兩個城市間可以有多條道路
,每條都視為是不同的。
Input
本題多個case,每個case:
輸入一個數字n表示有n條道路 0<n<10000
接下來n行每行讀入兩個數字 p1,p2 表示城市p1到p2有道路,並不表示p2到p1有道路 (0<=p1,p2<2^32)
輸入一個數字k表示有k個參賽人員
接下來k行,每行讀入四個資料v1,v2,t1,t2 (0<=t1,t2<10000)
輸入一個數字n表示有n條道路 0<n<10000
接下來n行每行讀入兩個數字 p1,p2 表示城市p1到p2有道路,並不表示p2到p1有道路 (0<=p1,p2<2^32)
輸入一個數字k表示有k個參賽人員
接下來k行,每行讀入四個資料v1,v2,t1,t2 (0<=t1,t2<10000)
Output
對於每組資料中的每個參賽人員輸出一個整數表示他獲得的金牌數(mod 2008)
Sample Input
6
1 2
1 3
2 3
3 2
3 1
2 1
3
1 2 0 0
1 2 1 100
4 8 3 50
Sample Output
0
1506
0
</pre><pre style="font-family: 'Courier New'; background-color: rgb(244, 251, 255);"><pre name="code" class="cpp">#include <algorithm>
#include <iostream>
#include <stdlib.h>
#include <string.h>
#include <iomanip>
#include <stdio.h>
#include <string>
#include <queue>
#include <cmath>
#include <stack>
#include <map>
#include <set>
#define eps 1e-10
///#define M 1000100
#define LL __int64
///#define LL long long
///#define INF 0x7ffffff
#define INF 0x3f3f3f3f
#define PI 3.1415926535898
#define zero(x) ((fabs(x)<eps)?0:x)
#define mod 2008
const int maxn = 210;
using namespace std;
struct matrix
{
int f[31][31];
};
matrix p[10001];
map<int, int>mp;
matrix mul(matrix a, matrix b, int n)
{
matrix c;
memset(c.f, 0, sizeof(c.f));
for(int i = 0; i < n; i++)
{
for(int j = 0; j < n; j++)
{
for(int k = 0; k < n; k++) c.f[i][j] += a.f[i][k]*b.f[k][j];
c.f[i][j] %= mod;
}
}
return c;
}
matrix pow_mod(matrix a, int b, int n)
{
matrix s;
memset(s.f, 0 , sizeof(s.f));
for(int i = 0; i < n; i++) s.f[i][i] = 1;
while(b)
{
if(b&1) s = mul(s, a, n);
a = mul(a, a, n);
b >>= 1;
}
return s;
}
matrix Add(matrix a,matrix b, int n)
{
matrix c;
for(int i = 0; i < n; i++)
{
for(int j = 0; j < n; j++)
{
c.f[i][j] = a.f[i][j]+b.f[i][j];
c.f[i][j] %= mod;
}
}
return c;
}
int main()
{
int n, m;
while(scanf("%d",&n)!=EOF)
{
int u, v;
int ans = 0;
mp.clear();
memset(p[0].f, 0, sizeof(p[0].f));
for(int i = 0; i < n; i++)
{
scanf("%d %d",&u, &v);
if(mp.find(u) == mp.end()) mp[u] = ans++;
if(mp.find(v) == mp.end()) mp[v] = ans++;
p[0].f[mp[u]][mp[v]] ++;
}
for(int i = 1; i < 10001; i++) p[i] = mul(p[i-1], p[0], ans);
scanf("%d",&m);
int t1, t2, v1, v2;
while(m--)
{
scanf("%d %d %d %d",&v1, &v2, &t1, &t2);
if(t1 > t2) swap(t1,t2);
if(mp.find(v1) == mp.end() || mp.find(v2) == mp.end() || t1 == 0 && t2 == 0)
{
puts("0");
continue;
}
int sum = 0;
for(int i = t1-1; i < t2; i++)
{
if(i == -1) continue;
sum += p[i].f[mp[v1]][mp[v2]]%mod;
}
printf("%d\n",sum%mod);
///cout<<(sum%mod)<<endl;
}
}
return 0;
}
相關文章
- 幸運數(dp+矩陣加速)矩陣
- HDU 1005 Number Sequence(矩陣快速冪)矩陣
- HDU 2256Problem of Precision(矩陣快速冪)矩陣
- HDU 2157 How many ways?? (矩陣快速冪)矩陣
- HDU 2276 - Kiki & Little Kiki 2 (矩陣快速冪)矩陣
- 矩陣論 戴華 高清矩陣
- HDU 4549 M斐波那契數列(矩陣快速冪+費馬小定理)矩陣
- 頭條號矩陣運營工具,運營矩陣進行多賬號管理矩陣
- Numpy中的矩陣運算矩陣
- 什麼是新媒體矩陣運營?運營矩陣其實很簡單矩陣
- bzoj4547: Hdu5171 小奇的集合(矩陣乘法)矩陣
- 高等代數1 矩陣矩陣
- 線性代數--矩陣矩陣
- pytorch基礎七(矩陣運算)PyTorch矩陣
- 大魚號矩陣管理助手,矩陣管理賬號,高效運營平臺矩陣
- HDU 1060 Leftmost Digit(數論,c++)GitC++
- 自媒體矩陣運營是什麼意思?自媒體矩陣應該怎麼運營?矩陣
- VIVADO vhdl verilog 實現矩陣運算矩陣
- verilog實現矩陣卷積運算矩陣卷積
- 矩陣運算與相抵標準型矩陣
- 矩陣指數的定義矩陣
- Max/MSP/Jitter 官方教程翻譯05 - 矩陣的數學運算矩陣
- 巨大的矩陣(矩陣加速)矩陣
- 鄰接矩陣、度矩陣矩陣
- 快手矩陣運營工具,矩陣運營多個快手賬號,一鍵分發多個平臺矩陣
- 奇異矩陣,非奇異矩陣,偽逆矩陣矩陣
- 矩陣類及其常規運算(加、減、乘、轉置、求逆、行列式、代數餘子式、伴隨矩陣)矩陣
- 巨大的數(dp+矩陣加速)矩陣
- 資料結構:陣列,稀疏矩陣,矩陣的壓縮。應用:矩陣的轉置,矩陣相乘資料結構陣列矩陣
- 矩陣矩陣
- 圖論——環測定與矩陣演算法圖論矩陣演算法
- 求任意矩陣的伴隨矩陣矩陣
- c語言中實現4行3列矩陣和3行4列矩陣的運算C語言矩陣
- Matlab矩陣運算的硬體資源分析Matlab矩陣
- Eigen教程(3)之矩陣和向量的運算矩陣
- 人工智慧數學基礎—-矩陣人工智慧矩陣
- 人工智慧數學基礎----矩陣人工智慧矩陣
- matlab計算含有未知數的矩陣Matlab矩陣
- 斐波那契數列Ⅳ【矩陣乘法】矩陣