阿牛的EOF牛肉串(杭电2047)

#include <stdio.h>

main()

{

    __int64 s,a,b;

    int n,i;

    while(scanf("%d",&n)!=EOF)

    {

        a=3;b=8;

        if(n<3)

        {

            if(n==1)

                printf("%I64d\n",a);

            else

                printf("%I64d\n",b);

        }

        else

        {

            for(i=2;i<n;i++)

            {

                s=(a+b)*2;         //本题规律:f(n)=(f(n-2)+f(n-1))*2,(n>2)

                a=b;

                b=s;

            }

            printf("%I64d\n",s);

        }

    }

    

}

注意:

1、输入数据包含多个测试实例,每个测试实例占一行,由一个整数n(0<n<40)组成。、

2、对于每个测试实例,要输出全部的满足要求的涂法,每个实例的输入占一行。

3、满足要求的字符串只能由E,O,F组成,且不能“OO”相邻的情况。

4、当n=1时,涂法有3种;当n=2时,涂法有8种;当n=3时,涂法有22种;当n=4时,      涂法有60种;当n=5时,涂法有164种;……

5、由4可以看出此题的规律为:f(n)=(f(n-2)+f(n-1))*2,(n>2)。

6、此题还要注意一点:由于此题输入的数据太大,已经超过int的取值范围。所以我们要用到__int64(输入输出格式为:%I64d)或者long long int(输入输出格式为:%lld)。

收获:

1、让我了解了:__int64型和long long int型,让我开了眼界。

2、当数据太大时,应该要考虑,是不是要换种想法来满足它的需要。

3、让我更深入的了解递推。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值