zoukankan      html  css  js  c++  java
  • 在时间复杂度O(logn)下求Fibonacci数列

    时间复杂度为O( n )的方法:

    long long Fibonacci( unsigned n )   
    {   
          int result[2] = {0, 1};   
          if(n < 2)   
                return result[n];   
    
          long long   fibOne = 0;   
          long long   fibTwo = 1;   
          long long   fibThree ;   
        
          for(unsigned int i = 2; i <= n; ++ i)   
           {   
                 fibThree = fibOne + fibTwo;   
          fibOne = fibTwo ;   
                 fibNTwo = fibThree;   
            }   
            return fibThree;   
    }
     
    
    /*
    下面介绍一种时间复杂度是O(logn)的方法:
    
    对于斐波那契数列1,1,2,3,5,8,13…….有如下定义:
    
    F( n ) = F( n-1 ) + F( n-2 )
    F( 1 ) = 1
    F( 2 ) = 1
    
    矩阵形式:
    
    [ F( n+1 ) ,  F( n ) ] = [ F( n ) , F( n-1 ) ] * Q  其中 [ F( n+1 ) ,  F( n ) ]为行向量,Q = { [ 1, 1 ]; [ 1, 0 ] }为矩阵
    
    则 [ F( n+1 ) , F( n ) ]=[ 1 , 0 ] * Qn , 
    */
     
    struct Matrix    
    {          
           long long m_00, m_01, m_10, m_11;   
       Matrix ( long long m00 = 0,  long long m01 = 0,  long long m10 = 0,   long long m11 = 0 )    
           :m_00( m00 ), m_01( m01 ), m_10( m10 ), m_11( m11 )     
           {    
           }    
    };
     
    
    Matrix MatrixMultiply (  const Matrix & m1, const Matrix & m2    )    
    {  
      long long m00 = m1.m_00 * m2.m_00 + m1.m_01 * m2.m_10;
      long long m01 = m1.m_00 * m2.m_01 + m1.m_01 * m2.m_11; 
      long long m10 = m1.m_10 * m2.m_00 + m1.m_11 * m2.m_10    
      long long m11 = m1.m_10 * m2.m_01 + m1.m_11 * m2.m_11; 
          return Matrix ( m00,  m01,  m10, m11 );    
    }
    
    Matrix MatrixPower( unsigned int n )    
    {    
           assert(n > 0);    
           Matrix m;    
           if( n == 1)    
           {    
                 m = Matrix(1, 1, 1, 0);    
           }    
          else if(n % 2 == 0)    
           {    
                 m = MatrixPower( n / 2 );    
                 m = MatrixMultiply( matrix, matrix );    
           }    
          else if( n % 2 == 1 )    
           {    
                 m = MatrixPower( (n - 1) / 2 );    
                 m = MatrixMultiply( m, m );    
                 m = MatrixMultiply( m, Matrix( 1, 1, 1, 0 ) );    
           }     
          return m;    
    }  
    long long Fibonacci( unsigned int n )
    {
          int result[2] = { 0, 1 };
          if( n < 2 )
                return result[ n ];
    
          Matrix Q = MatrixPower( n - 1 );  //注意:按定义式应该用[ 1, 0 ]*Q, 或者等价于{ [ 1 , 0 ]; [ 0, 0 ] }*Q, 但是因为显然结果相同,所以略去这一步。
          return Q.m_00;
    }

     

  • 相关阅读:
    vss的ss.ini丢失或损坏导致的vss无法登录错误
    NHibernate各种数据库连接参数文件配置方法说明
    oracle操作语句
    企业微信群聊机器人发送本地图片
    securecrt 或xshell 转发80端口
    SecureCRT 或 XSHELL 转发 X11 图形化GUI
    Windows 创建 .gdbinit 提示必须键入文件名
    vscode C++ 程序 windows
    vscode C++ 程序 windows
    解决source insight 4.0 不识别.cc文件的问题
  • 原文地址:https://www.cnblogs.com/kevinGaoblog/p/2435710.html
Copyright © 2011-2022 走看看