这道题,大家一定要注意:

要对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 【斐波那契数列(升级版)】的更多相关文章

  1. 洛谷——P2626 斐波那契数列(升级版)

    P2626 斐波那契数列(升级版) 题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f(n) = f(n-1) + f(n-2) (n ≥ ...

  2. 洛谷 P2626 斐波那契数列(升级版)

    题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f(n) = f(n-1) + f(n-2) (n ≥ 2 且 n 为整数). 题目描述 ...

  3. [洛谷P2626]斐波那契数列(升级版)

    题目大意:请你求出第$n$个斐波那契数列的数$mod 2^{31}$之后的值.并把它分解质因数. 题解:乱搞 卡点:1.忘记取模 C++ Code: #include<cstdio> #i ...

  4. [NOIP1997] P2626 斐波那契数列(升级版)

    题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f(n) = f(n-1) + f(n-2) (n ≥ 2 且 n 为整数). 题目描述 ...

  5. 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 ...

  6. 洛谷——P2626 斐波那契数列(升级版)矩阵

    题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f(n) = f(n-1) + f(n-2) (n ≥ 2 且 n 为整数). 题目描述 ...

  7. P2626 斐波那契数列(升级版)

    题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f(n) = f(n-1) + f(n-2) (n ≥ 2 且 n 为整数). 题目描述 ...

  8. P2626 斐波那契数列(升级版) 洛谷(2626)

    https://www.luogu.org/problem/show?pid=2626 题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f ...

  9. LintCode题解之斐波纳契数列

    直接使用递归的方法会导致TLE,加个缓存就好了: public class Solution { private Integer[] buff = new Integer[1000]; /* * @p ...

  10. HDU 5914 Triangle 斐波纳契数列 && 二进制切金条

    HDU5914 题目链接 题意:有n根长度从1到n的木棒,问最少拿走多少根,使得剩下的木棒无论怎样都不能构成三角形. 题解:斐波纳契数列,a+b=c恰好不能构成三角形,暴力就好,推一下也可以. #in ...

随机推荐

  1. msyql分区与分库分表

    分区 工作原理 对用户而言,分区表是一个独立的逻辑表,但是底层MySQL将其分成多个物理子表,这对用户来说是透明的,每一个分区表都会使用一个独立的表文件. 如果数据量比较大,可以进行分区.分区对PHP ...

  2. 文本处理三剑客之gawk

    gawk 作者:Aho, Weinberger, Kernighan 版本: GNU awk:gawk New awk:nawk 简介:格式化文本输出工具,模式扫描及处理语言:报告生成器. 用法:ga ...

  3. QPS,TPS,吞吐量,响应时间详解及关系

    并发数 并发数是指系统同时能处理的请求数量,这个也是反应了系统的负载能力 吞吐量吞吐量是指单位时间内系统能处理的请求数量,体现系统处理请求的能力,这是目前最常用的性能测试指标 响应时间RT(Respo ...

  4. 时间format函数引爆的知识点和年末有话说

    年末感慨 转眼之间,一年的最后一天来了. 2017,技术界貌似正在飞跃.多年的量变终于引起了质变. 人工智能,区块链.对此,我很激动,激动着有点害怕,害怕中有点紧张,还有点渴望.未来的至高点,未来的风 ...

  5. Python 起步 多版本共存配置

    上次我选择的是py2.x,如果我要再装一个py3.x呢 我们去设置环境变量,然后去命令行输入python,这里我故意把环境变量放在第一行,貌似换成3.7了 我们把2.7的放在3.7的前面呢?又换回去了 ...

  6. windows下运行jar

    run.bat 1. javaw运行 @echo offstart javaw -Xmx128m -Xms64m -jar testlog.jarexit 2.java运行 @echo offjava ...

  7. CollectionUtils.select 集合筛选

    import org.apache.commons.collections.CollectionUtils;import org.apache.commons.collections.Predicat ...

  8. JS——通过标签获取元素、循环语句、数组去重

    通过标签获取元素: var aLi = document.getElementsByTagName('Li'); aLi[0].style.backgroundColor = 'gold'; 选中部分 ...

  9. Murano中的角色

    Application Publisher - An individual or company that publishes an application to an application cat ...

  10. 模拟虚拟的文件系统initrd/initramfs

    请看initramfs文件的以下解析: [root@ant-colonies boot]# ls config--.el6.x86_64 lost+found efi symvers--.el6.x8 ...