我是靠谱客的博主 超级毛衣,最近开发中收集的这篇文章主要介绍HDU:2604 Queuing(发现似乎所有…,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

此题的题意是求出长度为L的 ,有f 和m 组成的窜中找出没有存在 fmf 和fff 的窜的个数

 

求解f[n]=f[n-1]+f[n-3]+f[n-4];我们就可以构造出这样的 矩阵

HDU:2604 <wbr>Queuing(发现似乎所有递推题都可以用矩阵乘法来做)

HDU:2604 <wbr>Queuing(发现似乎所有递推题都可以用矩阵乘法来做)
这是搜的代码:

 

#include <iostream>
using namespace std;

const int N = 4;

struct Mat
{
int matrix[N][N];
};

Mat mat, mt;
int n, m;

Mat mul(Mat a, Mat b)
{
int i, j, k;
Mat c;
for (i = 0; i < N; i++)
for (j = 0; j < N; j++)
{
c.matrix[i][j] = 0;
for (k = 0; k < N; k++)
{
c.matrix[i][j] += a.matrix[i][k] * b.matrix[k][j];
c.matrix[i][j] %= m;
}
}
return c;
}

Mat solve(int m)
{
Mat mt;

if (m == 1)
return mat;
if (m & 1)
return mul(solve(m - 1), mat);
else
{
mt = solve(m / 2);
return mul(mt, mt);
}
}

void init()
{
int i, j;
for (i = 0; i < N; ++i)
{
mat.matrix[0][i] = 1;
}
mat.matrix[0][1] = 0;
for (i = 1; i < N; ++i)
{
for (j = 0; j < N; ++j)
{
if (i - j == 1)
mat.matrix[i][j] = 1;
else
mat.matrix[i][j] = 0;
}
}
}
int main()
{
Mat ans;
int f41[] =
{ 9, 6, 4, 2 }, sum, f04[] =
{ 0, 2, 4, 6, 9 };
//freopen("t","r",stdin);
while (scanf("%d %d", &n, &m) != EOF)
{
if (n < 5)
{
printf("%dn", f04[n] % m);
}
else
{
init();
ans = solve(n - 4);
sum = 0;
for (int k = 0; k < N; k++)
{
sum += ans.matrix[0][k] * f41[k];
sum %= m;
}
printf("%dn", sum);
}
}
return 0;
}

 

最后

以上就是超级毛衣为你收集整理的HDU:2604 Queuing(发现似乎所有…的全部内容,希望文章能够帮你解决HDU:2604 Queuing(发现似乎所有…所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(56)

评论列表共有 0 条评论

立即
投稿
返回
顶部