题解 P2626 【斐波那契数列(升级版)】
这道题,大家一定要注意:
要对2^31取模 ! ( 本蒟蒻开始没注意到这一点,WA了 )
(不过大家在试样例的时候,试试47,出不了结果,就说明你没模2^31)
总体来说,这道题考查的知识点就两个:
① 斐波那契递推公式 ( a[n]=a[n-1]+a[n-2] )
② 分解质因数 ( 不要跟因式分解混淆了 )
首先,让我们来看一看斐波那契递推公式:
const long long x=pow(2,31);//2^31
a[1]=1;
a[2]=1;
for(i=3;i<=n;i++)
a[i]=(a[i-1]+a[i-2])%x;//long long a[49],i;
很简单吧!(只要记得公式就好办了)
其次,让我们看一看分解质因数:
for(i=2;a[n]>1;i++){
if(a[n]%i==0){//i是a[n]的因数
a[n]/=i;//记得要除
printf("%lld",i);
break;//先处理没有乘号的地方
}
}
for(j=i;a[n]>1;j++){
if(a[n]%j==0){//j是a[n]的因数
printf("*%lld",j);
a[n]/=j;//这里也是
while(a[n]%j==0){
printf("*%lld",j);
a[n]/=j;//还有这里
}
if(a[n]==1)//特判
return 0;//若a[n]为0则分解完毕,退出
}
}
只是要注意等号后面第一个不能输出乘号,得重复走两遍
贴出完整代码:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;//自定义
const long long x=pow(2,31);//pow(a,b)为计算a^b
ll i,n,j,a[51];//ll是自己定义的
int main(){
scanf("%lld",&n);
a[1]=1;
a[2]=1;
for(i=3;i<=n;i++)
a[i]=(a[i-1]+a[i-2])%x;//递推走起
printf("%lld=",a[n]);
for(i=2;a[n]>1;i++){
if(a[n]%i==0){
a[n]/=i;
printf("%lld",i);
break;
}
}
for(j=i;a[n]>1;j++){
if(a[n]%j==0){
printf("*%lld",j);
a[n]/=j;
while(a[n]%j==0){
printf("*%lld",j);
a[n]/=j;
}
if(a[n]==1)
return 0;
}
}//分解质因数
if(n==1||n==2)
printf("1");//不特判n=1和n=2时就无法输出
return 0;
}
洛谷加油!OI冲鸭!
题解 P2626 【斐波那契数列(升级版)】的更多相关文章
- 洛谷——P2626 斐波那契数列(升级版)
P2626 斐波那契数列(升级版) 题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f(n) = f(n-1) + f(n-2) (n ≥ ...
- 洛谷 P2626 斐波那契数列(升级版)
题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f(n) = f(n-1) + f(n-2) (n ≥ 2 且 n 为整数). 题目描述 ...
- [洛谷P2626]斐波那契数列(升级版)
题目大意:请你求出第$n$个斐波那契数列的数$mod 2^{31}$之后的值.并把它分解质因数. 题解:乱搞 卡点:1.忘记取模 C++ Code: #include<cstdio> #i ...
- [NOIP1997] P2626 斐波那契数列(升级版)
题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f(n) = f(n-1) + f(n-2) (n ≥ 2 且 n 为整数). 题目描述 ...
- P2626 斐波那契数列(升级版)(合数的质数分解, 大数为素数的概率十分小的利用)
题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: f(1)=1f(1) = 1 f(1)=1 f(2)=1f(2) = 1f(2)=1 f(n)=f(n−1)+f(n−2)f(n) = f ...
- 洛谷——P2626 斐波那契数列(升级版)矩阵
题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f(n) = f(n-1) + f(n-2) (n ≥ 2 且 n 为整数). 题目描述 ...
- P2626 斐波那契数列(升级版)
题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f(n) = f(n-1) + f(n-2) (n ≥ 2 且 n 为整数). 题目描述 ...
- P2626 斐波那契数列(升级版) 洛谷(2626)
https://www.luogu.org/problem/show?pid=2626 题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f ...
- LintCode题解之斐波纳契数列
直接使用递归的方法会导致TLE,加个缓存就好了: public class Solution { private Integer[] buff = new Integer[1000]; /* * @p ...
- HDU 5914 Triangle 斐波纳契数列 && 二进制切金条
HDU5914 题目链接 题意:有n根长度从1到n的木棒,问最少拿走多少根,使得剩下的木棒无论怎样都不能构成三角形. 题解:斐波纳契数列,a+b=c恰好不能构成三角形,暴力就好,推一下也可以. #in ...
随机推荐
- mui 上拉加载更多的使用
最近工作之余在用mui的框架开发,对mui了解了一些.在真正的app开发项目中,mui上拉加载模块中有两个坑,现在说一下. 1.在函数自己上拉加载行为后的回调函数 该函数是必须要写的,用来写自己的逻辑 ...
- .gitkeep--git提交空目录的解决方法
前言 git和 svn不同,仅仅跟踪文件的变动,不跟踪目录.所以,一个空目录,如果里面没有文件,即便 git add 这个目录,另外在别处 check out 的时候,是没有这个空目录的. 只跟踪文件 ...
- ng2学习--pipe使用
We use our custom pipe the same way we use built-in pipes.(自定义Pipe和API里自带的Pipe使用方式一致) We must includ ...
- selenium框架安装及webdriver安装
本文介绍的是selenium安装及webdriver安装.小实例 1.selenium介绍 selenium是一个用于web应用程序测试的工具. Selenium测试直接运行在浏览器,就向真正的用户操 ...
- python3——“->”的含义
->:标记返回函数注释,信息作为.__annotations__属性提供,__annotations__属性是字典.键return是用于在箭头后检索值的键.但是在Python中3.5,PEP 4 ...
- 002 Add Two Numbers 链表上的两数相加
You are given two non-empty linked lists representing two non-negative integers. The digits are stor ...
- Ubuntu上安装Samba服务器实现家庭共享
如何在Ubuntu上安装Samba服务器 大多数Linux发行版都包含Samba. 要在Ubuntu上安装Samba,只需运行: sudo apt install samba 要检查您的Samba版本 ...
- python_3 :用python微信跳一跳
[学习使用他人代码] 2018年01月21日 19:29:02 独行侠的守望 阅读数:319更多 个人分类: Python 编辑 版权声明:本文为博主原创文章,转载请注明文章链接. https://b ...
- Web框架的应用
从今天开始,我们将要学习有关Web框架的一些内容,在学习之前先来学习一下http协议,即基于http是如何通信的. http 概要:http是基于tcp/ip通信协议来传输数据的. 优点: 1.简单快 ...
- python基本数据类型,int,bool,str
一丶python基本数据类型 1.int 整数,主要用来进行数学运算. 2.str 字符串,可以保存少量数据并进行相应的操作 3.bool 判断真假.True.False 4.list 存储大量数据, ...