西雅图
18:14发布
西雅图
18:14发布
8°
东南风 4级
空气质量 无
相对湿度 90%
今天
中雨
6°/11°
周四
中雨
3°/10°
周五
2°/10°

一本通-P1799-数列

题目链接

f0 f1 f2 f3 f4 f5 f6 f7 f8 f9 f10
0 0 0 2 10 32 84 198 438 932 1936

我们发现

fi=2fi1+(i1)(i2)

我们可以设

gi=i(i1)

gi=i(i1)=(i1)(i2)+2(i1)=gi1+2(i1)


我们可以推出初始矩阵

[f0g001]=[0001]

第一个数是f0,第二个数是g0,第三个数是i,第四个数是1。
以及转移矩阵

[2000110002100011]

第一行对应的是f0,第二行对应的是g0,第三行对应的是i,第四行对应的是1。

对于题目给出的105000,本蒟蒻因为太弱,不想打高精,想到了使用类似于快速幂的方法,因为$an=(a)^{10}* a^y (10* x+y=n) $

可以直接避免高精

于是,我们就可以写出代码

#include<cstdio>
#include<cctype>
#include<cstring>
#define re register
#define ll long long
using namespace std;
const int N=1e7+10,mod=1e9+7;
struct matrix
{
	int n,m,g[5][5];
	inline void init(int _n,int _m)
	{
		memset(g,0,sizeof(g));
		n=_n;
		m=_m;
	}
	inline matrix operator *(const matrix &b)
	{
		matrix res;
		res.init(n,b.m);
		for(re int i=1; i<=res.n; i++)
			for(re int j=1; j<=res.m; j++)
				for(re int k=1; k<=b.n; k++)
					res.g[i][j]=(res.g[i][j]+1ll*g[i][k]*b.g[k][j])%mod;
		return res;
	}
	template<typename T>
	inline matrix operator ^ (T b)
	{
		matrix res,a=(*this);
		res.init(4,4);
		for(re int i=1; i<=4; i++)
			res.g[i][i]=1;
		while(b)
		{
			if(b&1)
				res=res*a;
			a=a*a;
			b>>=1;
		}
		return res;
	}
	inline void print()
	{
		for(re int i=1; i<=n; i++)
		{
			for(re int j=1; j<=m; j++)
				printf("%d ",g[i][j]);
			putchar('\n');
		}
		return;
	}
} a,b,f;
int n;
char s[5010];
int main()
{
	a.init(1,4);
	a.g[1][4]=1;
	b.init(4,4);
	b.g[1][1]=2;
	b.g[2][1]=b.g[2][2]=1;
	b.g[3][2]=2,b.g[3][3]=1;
	b.g[4][3]=b.g[4][4]=1;
	f.init(4,4);
	for(re int i=1; i<=4; i++)
		f.g[i][i]=1;
	scanf("%s",s+1);
	for(re int i=1; s[i]; i++)
		f=(f^10)*(b^((int)s[i]-'0'));
	printf("%d\n",(a*f).g[1][1]);
	return 0;
}

作者:蒟蒻wjr
欢迎任何形式的转载,但请务必注明出处。
限于本人水平,如果文章和代码有表述不当之处,还请不吝赐教。

posted @   蒟蒻wjr  阅读(260)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?

点击右上角即可分享
微信分享提示