| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 4184 人关注过本帖, 1 人收藏
标题:散分 终于找到了一个log n的算法来求斐波那契数列第n项
只看楼主 加入收藏
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
结帖率:95.24%
收藏(1)
已结贴  问题点数:100 回复次数:11 
散分 终于找到了一个log n的算法来求斐波那契数列第n项
Fibonacci
时间限制:5000 ms  |  内存限制:65536 KB
描述
Fibonacci数列是满足如下条件的整数数列:


F0 = 0


F1 = 1


FN = FN-1+FN-2 (N≥2)


Fibonacci数列的前10项如下:


0, 1, 1, 2, 3, 5, 8, 13, 21, 34, …


另一个求解Fibonacci数列的公式是:见下面帖子的图片


 


对于任意给定的整数N,请求出FN模10000的余数。


输入
输入包含多组测试数据。


每组数据占一行,仅包含一个整数n(0≤n≤1,000,000,000)最后一行为整数-1代表输入结束,不需要做处理。

输出
对于每组测试数据,输出FN模10000的余数。

样例输入
0
9
-1
样例输出
0
34

题目网址 http://www.

[ 本帖最后由 laoyang103 于 2011-10-15 15:22 编辑 ]
搜索更多相关主题的帖子: 测试 内存 
2011-10-15 15:20
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
图片附件: 游客没有浏览图片的权限,请 登录注册

程序代码:
//2ms AC代码
#include <stdio.h>
struct Matrix
{
    int _11,_12;
    int _21,_22;
};
void Ride(const Matrix *src1,const Matrix *src2,Matrix *out)
{
    out->_11 = (src1->_11*src2->_11 + src1->_12*src2->_21)%10000;
    out->_12 = (src1->_11*src2->_12 + src1->_12*src2->_22)%10000;
    out->_21 = (src1->_21*src2->_11 + src1->_22*src2->_21)%10000;
    out->_22 = (src1->_21*src2->_12 + src1->_22*src2->_22)%10000;
}
void Power(Matrix *src,int n,Matrix *out)
{
    Matrix one = {1,1,1,0};
    if(n == 1)
    {
        *out = one;
        return ;
    }
    Power(src,n>>1,out);
    Matrix temp = *out;
    Ride(&temp,&temp,out);
    if(0 == n%2)
        return ;
    else
    {
        temp = *out;
        Ride(&temp,&one,out);
    }
}
int main()
{
    int i,j,n;
    while(scanf("%d",&n) && n >=0)
    {
        if(0 == n || 1 == n)
        {
            printf("%d\n",n);
            continue;
        }
        Matrix m1 = {1,1,1,0},res;
        Power(&m1,n-1,&res);
        printf("%d\n",res._11);
    }
    return 0;
}

                                         
===========深入<----------------->浅出============
2011-10-15 15:22
BlueGuy
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:29
帖 子:4476
专家分:4055
注 册:2009-4-18
收藏
得分:17 
接分...

我就是真命天子,顺我者生,逆我者死!
2011-10-15 16:07
a5952036
Rank: 2
等 级:论坛游民
帖 子:65
专家分:94
注 册:2011-9-7
收藏
得分:17 
不懂  来拿分
2011-10-15 16:12
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
回复 3楼 BlueGuy
我相信老大不是为了解分来的

                                         
===========深入<----------------->浅出============
2011-10-15 16:19
nomify
Rank: 5Rank: 5
等 级:职业侠客
帖 子:79
专家分:366
注 册:2011-10-13
收藏
得分:17 
貌似见过这算法。
2011-10-15 16:27
lz1091914999
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:四川
等 级:贵宾
威 望:37
帖 子:2011
专家分:5959
注 册:2010-11-1
收藏
得分:17 
恩,Congratulations

My life is brilliant
2011-10-15 16:29
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
但是 我没见过 觉得很新鲜而且很高效  所以拿来分享一下

农村来的 没见过世面 呵呵

                                         
===========深入<----------------->浅出============
2011-10-15 16:36
nomify
Rank: 5Rank: 5
等 级:职业侠客
帖 子:79
专家分:366
注 册:2011-10-13
收藏
得分:0 
MIT 算法导论网上公开课里提到过,可以看看,还带中文字幕的哦。
2011-10-15 16:43
落叶深蓝色
Rank: 8Rank: 8
来 自:山东
等 级:蝙蝠侠
帖 子:319
专家分:807
注 册:2010-12-8
收藏
得分:17 
分。。。
2011-10-15 16:44
快速回复:散分 终于找到了一个log n的算法来求斐波那契数列第n项
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.031876 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved