NowCoder数列(矩阵快速幂变式)
2024-10-19 09:34:12
时间限制 3000 ms 内存限制 32768 KB 代码长度限制 100 KB
题目描述
NowCoder最近在研究一个数列:
* F(0) = 7
* F(1) = 11
* F(n) = F(n-1) + F(n-2) (n≥2)
他称之为NowCoder数列。请你帮忙确认一下数列中第n个数是否是3的倍数。
输入描述:
输入包含多组数据。
每组数据包含一个整数n,(0≤n≤1000000)。
输出描述:
对应每一组输入有一行输出。
如果F(n)是3的倍数,则输出“Yes”;否则输出“No”。
输入例子:
0
1
2
3
4
5
输出例子:
No
No
Yes
No
No
No
题解:我最初的想法是肯定是矩阵快速幂的变式题,就想用矩阵快速幂,并且可以回顾一下矩阵快速幂,但是发现这题没我想的那么简单,我忽略的点在于取模的时候是对1000000007取得,不是足够大,会出现1000000007*3的倍数的情况,然后改成了0x3f3f3f3f再对3取模就可以了,当然网上有更为简单的方法,是找规律的,但是我觉得可以当作矩阵快速幂的变式练习来做。
PS:最近身体真的每况愈下。。。要加强锻炼了。
附上代码:
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#define MOD 0x3f3f3f3f
using namespace std;
typedef long long int ll;
int flag;
struct mat
{
ll a[4][4];
}ans,res;
mat Mul(mat x,mat y)
{
mat t;
memset(t.a,0,sizeof(t.a));
for(int i=0;i<2;i++)
{
for(int j=0;j<2;j++)
{
for(int k=0;k<2;k++)
{
t.a[i][j]+=(x.a[i][k]*y.a[k][j]);
t.a[i][j]%=MOD;
}
}
}
return t;
}
void quickMod(long long int N)
{
ans.a[0][0]=11;
ans.a[0][1]=7;
ans.a[1][0]=7;
ans.a[1][0]=0;
while(N)
{
if(N&1)
{
ans=Mul(ans,res);
}
res=Mul(res,res);
N>>=1;
}
}
int main()
{
ll n;
while(scanf("%lld",&n)!=EOF)
{
flag=0;
res.a[0][0]=1;
res.a[0][1]=1;
res.a[1][0]=1;
res.a[1][1]=0;
if(n==0)
{
printf("No\n");
}
else if(n==1)
{
printf("No\n");
}
else
{
quickMod(n-1);
if(ans.a[0][0]%3==0||flag==1)
{
printf("Yes\n");
}
else
{
printf("No\n");
}
}
}
return 0;
}
最新文章
- 【转】关于FLASH中图文混排聊天框的小结
- jquery 抽奖示例
- [Linux] -Docker修改空间大小
- delphi.thread.线程循环执行体结构
- Spring中@Autowired注解、@Resource注解的区别
- oc-12-NSString 类简单介绍及用法
- Linux--------------安装nginx ftp
- wp8模拟器中使用电脑键盘和模拟器的版本解释
- freemarker使用map
- IE 文档模型设置 免去你IE 按F12去调文档标准的烦恼。
- [原创作品]html css改变浏览器选择文字的背景和颜色
- AnsiString用法(转)
- 直接用nose进行django项目测试并输出html报告
- C#3.0中的扩展方法
- IOS开发之XCode学习008:UIViewController基础
- 痞子衡嵌入式:蓝牙芯片厂商三强(Qualcomm&;CSR, TI, Nordic)产品一览
- vue的插槽slot
- [转]group by 后使用 rollup 子句总结
- 16.Mongodb安装
- ZooKeeper系列之二:Zookeeper常用命令
热门文章
- mybatis中in查询
- Python之POST登录测试
- eclipse中。安装findbugs java检测工具
- maven手动安装oracle驱动到仓库
- 使用ffmpeg压缩视频
- ReactNative http网络通讯
- js 控制标记样式
- google浏览器:Ignored call to &#39;confirm()&#39;. The document is sandboxed, and the &#39;allow-modals&#39; keyword is not set
- Ubuntu重启关机命令使用
- patch请求--501错误