C#,广义斐波那契数(Generalised Fibonacci Numbers)的算法

广义斐波那契序列(generalized Fibonacci sequence)是斐波那契数的推广。由递推关系F₁=F₂=...=Fm-1=0,Fₘ=1,Fm+n=Fₙ+Fn+1+...+Fn+m+1,n≥1所产生的序列,称为m级广义斐波那契序列。

计算结果:

源代码:

1 文本格式

using System;

namespace Legalsoft.Truffer.Algorithm

{

/// <summary>

/// 广义斐波那契数

/// Generalised Fibonacci Numbers

/// </summary>

public static partial class Number_Sequence

{

/// <summary>

/// 广义斐波那契数的算法

/// </summary>

/// <param name="N"></param>

/// <param name="a"></param>

/// <param name="b"></param>

/// <param name="m"></param>

/// <param name="n"></param>

/// <returns></returns>

public static int Generalized_Fibonacci_Number(int N, int a, int b, int m, int n)

{

int[,] F = { { m, 1 }, { n, 0 } };

if (N == 0)

{

return a;

}

if (N == 1)

{

return b;

}

if (N == 2)

{

return m * b + n * a;

}

int[,] initial = { { m * b + n * a, b }, { b, a } };

GFN_Power(ref F, N - 2, m, n);

Fib_Multiply(ref initial, F);

return F[0, 0];

}

/// <summary>

/// 2x2矩阵乘法

/// </summary>

/// <param name="F"></param>

/// <param name="M"></param>

static void Fib_Multiply(ref int[,] F, int[,] M)

{

int x = F[0, 0] * M[0, 0] + F[0, 1] * M[1, 0];

int y = F[0, 0] * M[0, 1] + F[0, 1] * M[1, 1];

int z = F[1, 0] * M[0, 0] + F[1, 1] * M[1, 0];

int w = F[1, 0] * M[0, 1] + F[1, 1] * M[1, 1];

F[0, 0] = x;

F[0, 1] = y;

F[1, 0] = z;

F[1, 1] = w;

}

private static void GFN_Power(ref int[,] F, int N, int m, int n)

{

int[,] M = { { m, 1 }, { n, 0 } };

for (int i = 1; i <= N; i++)

{

Fib_Multiply(ref F, M);

}

}

}

}


POWER BY TRUFFER.CN

2 代码格式

cs 复制代码
using System;

namespace Legalsoft.Truffer.Algorithm
{
    /// <summary>
    /// 广义斐波那契数
    /// Generalised Fibonacci Numbers
    /// </summary>
    public static partial class Number_Sequence
    {
        /// <summary>
        /// 广义斐波那契数的算法
        /// </summary>
        /// <param name="N"></param>
        /// <param name="a"></param>
        /// <param name="b"></param>
        /// <param name="m"></param>
        /// <param name="n"></param>
        /// <returns></returns>
        public static int Generalized_Fibonacci_Number(int N, int a, int b, int m, int n)
        {
            int[,] F = { { m, 1 }, { n, 0 } };
            if (N == 0)
            {
                return a;
            }
            if (N == 1)
            {
                return b;
            }
            if (N == 2)
            {
                return m * b + n * a;
            }
            int[,] initial = { { m * b + n * a, b }, { b, a } };
            GFN_Power(ref F, N - 2, m, n);
            Fib_Multiply(ref initial, F);
            return F[0, 0];
        }

        /// <summary>
        /// 2x2矩阵乘法
        /// </summary>
        /// <param name="F"></param>
        /// <param name="M"></param>
        static void Fib_Multiply(ref int[,] F, int[,] M)
        {
            int x = F[0, 0] * M[0, 0] + F[0, 1] * M[1, 0];
            int y = F[0, 0] * M[0, 1] + F[0, 1] * M[1, 1];
            int z = F[1, 0] * M[0, 0] + F[1, 1] * M[1, 0];
            int w = F[1, 0] * M[0, 1] + F[1, 1] * M[1, 1];

            F[0, 0] = x;
            F[0, 1] = y;
            F[1, 0] = z;
            F[1, 1] = w;
        }

        private static void GFN_Power(ref int[,] F, int N, int m, int n)
        {
            int[,] M = { { m, 1 }, { n, 0 } };
            for (int i = 1; i <= N; i++)
            {
                Fib_Multiply(ref F, M);
            }
        }
    }
}
相关推荐
zheyutao4 分钟前
字符串哈希
算法
A尘埃12 分钟前
保险公司车险理赔欺诈检测(随机森林)
算法·随机森林·机器学习
Porco.w43 分钟前
C#与三菱PLC FX5U通信
网络·c#
大江东去浪淘尽千古风流人物1 小时前
【VLN】VLN(Vision-and-Language Navigation视觉语言导航)算法本质,范式难点及解决方向(1)
人工智能·python·算法
努力学算法的蒟蒻2 小时前
day79(2.7)——leetcode面试经典150
算法·leetcode·职场和发展
2401_841495642 小时前
【LeetCode刷题】二叉树的层序遍历
数据结构·python·算法·leetcode·二叉树··队列
AC赳赳老秦2 小时前
2026国产算力新周期:DeepSeek实战适配英伟达H200,引领大模型训练效率跃升
大数据·前端·人工智能·算法·tidb·memcache·deepseek
2401_841495642 小时前
【LeetCode刷题】二叉树的直径
数据结构·python·算法·leetcode·二叉树··递归
budingxiaomoli2 小时前
优选算法-字符串
算法
qq7422349842 小时前
APS系统与OR-Tools完全指南:智能排产与优化算法实战解析
人工智能·算法·工业·aps·排程