关闭

[1021]:Fibonacci Again

标签: acm-FiAgai
228人阅读 评论(0) 收藏 举报
分类:

Fibonacci Again

Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 46300 Accepted Submission(s): 22077

Problem Description
There are another kind of Fibonacci numbers: F(0) = 7, F(1) = 11, F(n) = F(n-1) + F(n-2) (n>=2).

Input
Input consists of a sequence of lines, each containing an integer n. (n < 1,000,000).

Output
Print the word “yes” if 3 divide evenly into F(n).

Print the word “no” if not.

Sample Input
0
1
2
3
4
5

Sample Output
no
no
yes
no
no
no

解题思路:刚开始看,这道题好像很容易,不就是求能否整除3吗?那就找一下规律(如:图一)不过会让你出错的地方是:(n < 1,000,000).,由于给出的n的范围偏大,这可能会是F(n)达到一定程度而溢出
这里写图片描述

#include<stdio.h>
#define F0 7
#define F1 11//题意给出的F(0) F(1)

int num;
int main()
{
    while(scanf("%d", &num)!=EOF){
        int a = F0%3, b = F1%3, n=2;
        if(num==0 || num==1){
            printf("no\n");
        }
        else{
            for(; n<=num; n++){
            int left = (a+b)%3;//①这一部分解释如图一
            a = b;
            b = left;
            if(left%3==0 && n==num){
                printf("yes\n");
            }
            else if(left%3!=0 && n==num){
                printf("no\n");
            }
            }
        }
    }
    return 0;
}

这里写图片描述

如果有类似的Fibonacci Again题目,我抽出一个可以用的模板:

0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

51nod1021石子归并(区间dp)

#include #include #include using namespace std; int n; int a[205],sum[205]; int dp[205][205];//数组...
  • zcmartin2014214283
  • zcmartin2014214283
  • 2016-04-19 15:06
  • 539

求Fibonacci数列的三种思路和算法(C++实现)

摘要:本文主要介绍求Fibonacci数列的三种思路和算法:二分递归、线性递归和动态规划法,并直观得体现了三者得运行效率的不同。
  • icurious
  • icurious
  • 2016-11-12 20:41
  • 1926

蓝桥杯- 入门训练 Fibonacci数列

问题描述 Fibonacci数列的递推公式为:Fn=Fn-1+Fn-2,其中F1=F2=1。 当n比较大时,Fn也非常大,现在我们想知道,Fn除以10007的余数是多少。
  • rl529014
  • rl529014
  • 2016-02-22 13:19
  • 1191

CCF NOI1021 发放奖金

问题链接:CCF NOI1021 发放奖金。 时间限制: 1000 ms  空间限制: 262144 KB 题目描述   企业发放的奖金根据利润分段计算提成。当利润I低于或等于10万元的,...
  • tigerisland45
  • tigerisland45
  • 2017-04-21 04:05
  • 516

fibonacci数列C++语言多种实现

转载时请注明出处和作者联系方式 文章出处:http://blog.csdn.net/chenchong08 作者联系方式:vision_chen@yeah.net 斐波纳契数列(Fibona...
  • roney123
  • roney123
  • 2015-12-20 00:24
  • 286

Fibonacci 数列及其计算方法

Fibonacci 数列及其计算方法斐波那契数列(Fibonacci sequence),又称黄金分割数列,这个数列最早是由印度数学家提出来的。不过更多的人学习到这个数列是因为意大利数学家列昂纳多·斐...
  • liyuanbhu
  • liyuanbhu
  • 2016-06-17 23:02
  • 7527

51Nod 1021 石子归并(经典dp)

1021 石子归并 N堆石子摆成一条线。现要将石子有次序地合并成一堆。规定每次只能选相邻的2堆石子合并成新的一堆,并将新的一堆石子数记为该次合并的代价。计算将N堆石子合并成一堆的最小代价...
  • qq_33850438
  • qq_33850438
  • 2016-03-18 20:43
  • 830

黄金分割法与Fibonacci法

最近在上一门最优化算法的课,于是就打算写一篇博客来将自己所学的知识做一个巩固,这两种方法都是用来选取函数的极值点,属于的一维搜索方法中的试探法,方式也是很简单那就是在值域[a,b][a, b]内选取两...
  • zp1996323
  • zp1996323
  • 2016-04-15 20:10
  • 349

求Fibonacci数的三种方法和时间复杂度解析

求Fibonacci数最快的方法,时间复杂度O(log n)
  • deping_chen
  • deping_chen
  • 2014-05-11 12:58
  • 3171

优美的Fibonacci数列与矩阵

题目:http://codeforces.com/contest/392/problem/C   题意:给定Fibonacci数列F[],令,求的值。   分析:对于Fibonacci数列的题目来说一...
  • ACdreamers
  • ACdreamers
  • 2014-05-09 16:11
  • 1650
    个人资料
    • 访问:70384次
    • 积分:2782
    • 等级:
    • 排名:第14884名
    • 原创:217篇
    • 转载:0篇
    • 译文:0篇
    • 评论:3条
    最新评论