nefu 507 A short problem
题目:http://acm.nefu.edu.cn/test/problemshow.php?problem_id=507
思路:呵呵 三层一层一层迭代求出循环节。

#include <cstdio> #include <iostream> #include <cstring> #include <cmath> #include <algorithm> using namespace std; // 1e9+7 // 222222224 // 183120 int main() { long long a=0,b=1; long long mod=222222224; long long ans=1; long long c=(3*b+a)%mod; a=b; b=c; while(b!=1||a!=0) { ans++; c=(3*b+a)%mod; a=b; b=c; } cout<<ans<<endl; return 0; }

#include <cstdio> #include <iostream> #include <cmath> #include <cstring> #include <algorithm> using namespace std; struct Matrix { long long m[3][3]; }E,D; long long mod; void init() { for(int i=1;i<=2;i++) for(int j=1;j<=2;j++) E.m[i][j]=(i==j); D.m[1][1]=3; D.m[2][1]=D.m[1][2]=1; D.m[2][2]=0; } Matrix multi(Matrix A,Matrix B) { Matrix ans; for(int i=1;i<=2;i++) for(int j=1;j<=2;j++) { ans.m[i][j]=0; for(int k=1;k<=2;k++) ans.m[i][j]=(ans.m[i][j]+A.m[i][k]*B.m[k][j])%mod; } return ans; } Matrix Pow(Matrix A,long long k) { Matrix ans=E; while(k) { if(k&1) { k--; ans=multi(A,ans); } else { k/=2; A=multi(A,A); } } return ans; } int main() { init(); long long n; while(scanf("%lld",&n)!=EOF) { mod=183120; n%=mod; Matrix ans=Pow(D,n); mod=222222224; ans=Pow(D,ans.m[2][1]%mod); mod=1e9+7; ans=Pow(D,ans.m[2][1]%mod); printf("%lld\n",ans.m[2][1]); } return 0; }
标签:
water
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 后端思维之高并发处理方案
· 理解Rust引用及其生命周期标识(下)
· 从二进制到误差:逐行拆解C语言浮点运算中的4008175468544之谜
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· 后端思维之高并发处理方案
· 千万级大表的优化技巧
· 在 VS Code 中,一键安装 MCP Server!
· 想让你多爱自己一些的开源计时器
· 10年+ .NET Coder 心语 ── 继承的思维:从思维模式到架构设计的深度解析