欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C# 遞歸算法詳解

 更新時間:2021年11月05日 09:38:16   作者:智者見智  
什么是遞歸函數/方法?任何一個方法既可以調用其他方法也可以調用自己,而當這個方法調用自己時,我們就叫它遞歸函數或遞歸算法,接下來詳細介紹需要了解的朋友可以參考下

1)1、1、2、3、5、8.......用遞歸算法求第30位數的值?

首先我們能夠發(fā)現(xiàn)從第3位數起后一位數等于前兩位數值之和,即:x=(x-1)+(x-2),x>2;

這里須要不斷的相加,第一時刻就會想到循環(huán)處理,我們嘗試用數組去裝載這些數值,即:

int[] a=new int[30];
 a[0]=1;
 a[1]=1;
 for(int i=2;i<30;i++)
{
    a[i]=a[i-1]+a[i-2];
}

求a[29]的值即為第30位數的值,遞歸該怎樣處理呢?相同定義函數

fun(n)
{
    return fun(n-1)+fun(n-2)//n為第幾位數,第n位數返回值等于第n-1位數的值與第n-2位數的值之和
}

僅僅有當n>2為這樣的情況,就能夠做個推斷

fun(n)
{
     if(n==1 || n==2)
          return 1;
     else
          return fun(n-1)+fun(n-2);
}

求fun(30);

2)編寫計算斐波那契(Fibonacci)數列的第n項函數fib(n)斐波那契數列為:0、1、1、2、3、……,

即:

fib(0)=0;

fib(1)=1;

fib(n)=fib(n-1)+fib(n-2) (當n>1時)

寫成遞歸函數有:

int fib(int n) 
{
  if (n==0) return 0; 
  if (n==1) return 1; 
  if (n>1) return fib(n-1)+fib(n-2); 
}

遞歸算法的運行過程分遞推和回歸兩個階段。在遞推階段,把較復雜的問題(規(guī)模為n)的求解推到比原問題簡單一些的問題(規(guī)模小于n)的求解。

比如上例中,求解fib(n),把它推到求解fib(n-1)和fib(n-2)。也就是說,為計算fib(n),必須先計算fib(n-1)和fib(n-2),而計算fib(n-1)和fib(n-2),又必須先計算fib(n-3)和fib(n-4)。依次類推,直至計算fib(1)和fib(0),分別能馬上得到結果1和0。在遞推階段,必需要有終止遞歸的

情況。比如在函數fib中,當n為1和0的情況。

在回歸階段,當獲得最簡單情況的解后,逐級返回,依次得到稍復雜問題的解,比如得到fib(1)和fib(0)后,返回得到fib(2)的結果,……,在得到了fib(n-1)和fib(n-2)的結果后,返回得到fib(n)的結果。

在編寫遞歸函數時要注意,函數中的局部變量和參數知識局限于當前調用層,當遞推進入“簡單問題”層時,原來層次上的參數和局部變量便被隱蔽起來。在一系列“簡單問題”層,它們各有自己的參數和局部變量。

因為遞歸引起一系列的函數調用,而且可能會有一系列的反復計算,遞歸算法的運行效率相對較低。當某個遞歸算法能較方便地轉換成遞推算法時,通常按遞推算法編敲代碼。比如上例計算斐波那契數列的第n項的函數fib(n)應採用遞推算法,即從斐波那契數列的前兩項出發(fā),逐次由前兩項計算出下一項,直至計算出要求的第n項。

3)求1+2+3+4+5+....+n的值

Fun(n)=n+Fun(n-1)
n=1時為1
Fun(n)
{
     if(n==1)
       return 1;
     else
      return n+Fun(n-1);
}

4)有兩個整數型數組,從小到大排列,編寫一個算法將其合并到一個數組中,并從小到大排列

public void Fun()
    {
        int[] a = { 1, 3, 5, 7, 9, 10 };
        int[] b = { 2, 4, 6, 8, 11, 12, 15 };
        int[] c = new int[a.Length + b.Length];
        ArrayList al=new ArrayList();
        int i=0;
        int j=0;
        while (i <= a.Length - 1 && j <= b.Length - 1)
        {  //循環(huán)比較把小的放到前面
            if (a[i] < b[j])
            {
                al.Add(a[i++]);
            }
            else
            {
                al.Add(b[j++]);
            }
        }
        //兩個數組的長度不一樣,必有個數組沒比較完
        while (i <= a.Length - 1)//加入a中剩下的
        {
            al.Add(a[i++]);
        }
        while (j <= b.Length - 1)//加入b中剩下的
        {
            al.Add(b[j++]);
        }
        for (int ii = 0; ii <= c.Length-1 ; ii++)
        {
            c[ii] = (int)al[ii];
        }
    }

總結

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!

相關文章

  • C# [ImportDll()] 知識小結

    C# [ImportDll()] 知識小結

    今天小編就為大家分享一篇關于C# [ImportDll()] 知識小結,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • C#調用百度地圖API根據地名獲取經緯度geocoding

    C#調用百度地圖API根據地名獲取經緯度geocoding

    本文主要介紹了C#調用百度地圖API根據地名獲取經緯度geocoding,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • C#中的數組作為參數傳遞所引發(fā)的問題

    C#中的數組作為參數傳遞所引發(fā)的問題

    這篇文章主要介紹了C#中的數組作為參數傳遞所引發(fā)的問題 的相關資料,需要的朋友可以參考下
    2016-03-03
  • C#事件管理器如何清空所有監(jiān)聽詳解

    C#事件管理器如何清空所有監(jiān)聽詳解

    這篇文章主要給大家介紹了關于C#事件管理器如何清空所有監(jiān)聽的相關資料,文中通過示例代碼以及圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2020-07-07
  • C#操作DataTable方法實現(xiàn)過濾、取前N條數據及獲取指定列數據列表的方法

    C#操作DataTable方法實現(xiàn)過濾、取前N條數據及獲取指定列數據列表的方法

    這篇文章主要介紹了C#操作DataTable方法實現(xiàn)過濾、取前N條數據及獲取指定列數據列表的方法,實例分析了C#操作DataTable的各種常用技巧,非常具有實用價值,需要的朋友可以參考下
    2015-04-04
  • C#圖片處理3種高級應用

    C#圖片處理3種高級應用

    本文介紹C#圖片處理高級應用,這些功能并無多大技術含量。全部基于.Net Framework類庫完成,代碼中包含了C#圖片處理的一些基礎知識,與大家分享,個人能力有限,不足之處還請及時指正。
    2015-10-10
  • Unity3D游戲開發(fā)數據持久化PlayerPrefs的用法詳解

    Unity3D游戲開發(fā)數據持久化PlayerPrefs的用法詳解

    在本篇文章里小編給大家整理了關于Unity3D游戲開發(fā)之數據持久化PlayerPrefs的使用的相關知識點內容,需要的朋友們參考下。
    2019-08-08
  • 詳解C# FileStream類

    詳解C# FileStream類

    這篇文章主要介紹了詳解C# FileStream類的相關知識,文中講解的非常細致,代碼供大家參考和學習,感興趣的朋友可以了解下
    2020-06-06
  • 深入IComparable與IComparer的排序實例詳解

    深入IComparable與IComparer的排序實例詳解

    本篇文章是對IComparable與IComparer的排序實例進行了詳細的分析介紹,需要的朋友參考下
    2013-06-06
  • C#設計模式之職責鏈模式示例詳解

    C#設計模式之職責鏈模式示例詳解

    這篇文章主要給大家介紹了關于C#設計模式之職責鏈模式的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12

最新評論