zoukankan      html  css  js  c++  java
  • 题解:2018级算法第五次上机 小面包

    题目描述:

     

    样例:

    实现解释:

    斐波那契的简易变形

    知识点:

    斐波那契,递推

      首先对题目描述进行简化:有一个2*N的矩形,需要用无限个1*2和2*2的方块装满这个矩形,N最小为0最大为250(都除以三)。

      则所需要做的就是从N为0一直递增到250即可,在开始递推前先设置初值:N为0,放不下所以choise[0]=0,N为1,只能1*2的方块横放,所以choice[1]=1,N为2,可以两个1*2横放,两个1*2竖放,可以一个2*2放,choice[2] =3。

      当N大于2时,很显然可以依靠N-1,N-2两种情况得出N情况的情况种类,对N-1,多的1只能1*2横放,所以choice[N]+=choice[N-1],对N-2,可能会率先想到三种所以+=3*choice[N-2]即可,但是这里就有一个需要考虑的,这三种情况中有一种是两个1*2横放,因此会和N-1的那种情况有重合,因此在N-2再向上增加上只能两种:一个2*2或两个1*2竖放。因此还需要choice[N-2]*2。

      由此便可得递推公式:choice[i]+=choice[i-1]+2*choice[i-2]。

      注意取模运算每次都要进行即可。

    坑点:

    递推时对三种方法不重复选择的实现,取模

    完整代码:

    其实非常短,毕竟斐波那契

    #include<iostream>
    using namespace std; 
    #define MOD 1000007
    long long choice[251];
    int main()
    {
        ios::sync_with_stdio(false);
        int n;
        choice[0] = 0;
        choice[1] = 1;
        choice[2] = 3;
        for(int i = 3;i<=250;i++)
        {
            choice[i] += choice[i-1];
            choice[i]%=MOD;
            choice[i] += (2*choice[i-2])%MOD;
            choice[i]%=MOD;
        }
        while(cin >> n)
        {
            n/=3;
            cout << choice[n]%MOD << '
    ';
        }
        return 0;
    }
    View Code
  • 相关阅读:
    glog的编译和使用
    FFMPEG+SDL实现视频播放器
    SDL2学习(二):常用枚举值和函数
    SDL2学习(一): 显示一张图片
    2. chromium开发工具--gclient
    C# 获取时间大全
    用jquery-table2excel,进行导出excel
    SQL Server FOR XML PATH 和 STUFF函数的用法
    关于My Sql update语句不能用子查询的解决办法
    echarts呈现数据表图形
  • 原文地址:https://www.cnblogs.com/doUlikewyx/p/11906583.html
Copyright © 2011-2022 走看看