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

C語言數(shù)據(jù)結(jié)構(gòu)遞歸之斐波那契數(shù)列

 更新時間:2017年10月31日 08:47:02   作者:Vit_rose  
這篇文章主要介紹了C語言數(shù)據(jù)結(jié)構(gòu)遞歸之斐波那契數(shù)列的相關(guān)資料,希望通過本文能幫助到大家,讓大家理解掌握這部分內(nèi)容,需要的朋友可以參考下

C語言數(shù)據(jù)結(jié)構(gòu)遞歸之斐波那契數(shù)列

因為自己對遞歸還是不太熟練,于是做POJ1753的時候就很吃力,就是翻棋子直到棋盤上所有棋子的顏色一樣為止,求最少翻多少次,方法是枚舉遞歸。然后就打算先做另一道遞歸的題(從數(shù)組中取出n個元素的組合),但是同樣在遞歸的問題上不太理解。好吧,于是復(fù)習(xí)CPP,在第229頁的時候,看到了斐波那契數(shù)列,回想起之前做過的一道題目,發(fā)現(xiàn)可以用遞歸的方法來做。于是決定優(yōu)化一下之前的代碼。

以下這段摘自《C primer plus》

斐波那契數(shù)列的定義如下:第一個和第二個數(shù)字都是1,而后續(xù)的每個數(shù)字是其前兩個數(shù)字之和,例如,數(shù)列中前幾個數(shù)字是1,1,2,3,5,8和13?!旅嫖覀儎?chuàng)建一個函數(shù),它接受一個正整數(shù)n作為參數(shù),返回相應(yīng)的斐波那契數(shù)值。

首先,關(guān)于遞歸深度,遞歸提供了一個簡單的定義。如果調(diào)用Fibonacci(),當(dāng)n為1或2時Fibonacci(n)應(yīng)返回1;對于其他數(shù)值應(yīng)返回Fibonacci(n-1)+Fibonacci(n-2);

long Fibonacci(n)
{
  if (n > 2)
    return Fibonacci(n-1)+Fibonacci(n-2);
  else
    return 1;
}

然后是兔子總數(shù)問題。

有一對兔子,從出生后第三個月起每個月都生一對兔子,小兔子長到第三個月后又生一對兔子,假如兔子都不死,每個月兔子對數(shù)為多少?

思考這道題的時候,如果你簡單的推算一下,會發(fā)現(xiàn)兔子每個月的對數(shù)就是斐波那契數(shù)列。

第一個月:1對;
第二個月:1對;
第三個月:2對;
第四個月:3對:
第五個月:5對:
第六個月:8對;
……

我之前做這道題的時候,覺得思路很簡單,就是從第三個月起,求每個月的兔子數(shù)時,只要把這個月的前兩個月總數(shù)相加。
這是我之前的代碼,用f1和f2表示月。:

#include<stdio.h>
int main()
{
  int f1,f2;
  int month,ct;
  printf("請輸入月份:");
  scanf("%d",&month);
  if(month<=2)
    printf("兩只。\n");
  if (month > 2)
  {
    f1 = f2 = 1;
    ct = 0;
    while(ct < month -2){
      f1 = f1+f2;
      ct += 1;
      f2 = f1+f2;
      ct += 1;
    }
    if (month %2 == 0){
      printf("第 %d 個月的兔子對數(shù)為:%d.\n",month,f2);
    }
    if (month %2 == 1){
      printf("第 %d 個月的兔子對數(shù)為:%d.\n",month,f1);
    }
  }
  return 0;
}

其實這個代碼離遞歸就差一步,很接近了。但是我當(dāng)時完全沒有想到。

這是我重新修改之后的代碼:

#include<stdio.h>
long Fibonacci(n)
{
  if (n > 2)
    return Fibonacci(n-1)+Fibonacci(n-2);
  else
    return 1;
}
int main()
{
  long num;
  int month;
  printf("請輸入月份:");
  scanf("%d",&month);
  num = Fibonacci(month);
  printf("這個月的兔子對數(shù)為%d.\n",num);
  return 0;
}

只是很簡單的修改,但是代碼就整潔易懂了很多,也學(xué)到了新內(nèi)容。

工欲善其事必先利其器,共勉。

如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • C++超詳細(xì)講解析構(gòu)函數(shù)

    C++超詳細(xì)講解析構(gòu)函數(shù)

    既然在創(chuàng)建對象時有構(gòu)造函數(shù)(給成員初始化),那么在銷毀對象時應(yīng)該還有一個清除成員變量數(shù)據(jù)的操作咯,析構(gòu)函數(shù)與構(gòu)造函數(shù)功能相反,析構(gòu)函數(shù)不是完成對象的銷毀,局部對象銷毀工作是由編譯器完成的。而對象在銷毀時會自動調(diào)用析構(gòu)函數(shù),完成類的一些資源清理工作
    2022-06-06
  • 如何解決C++未定義標(biāo)識符 “string“、未定義標(biāo)識符 “cout“、“name”:未知重寫說明符錯誤

    如何解決C++未定義標(biāo)識符 “string“、未定義標(biāo)識符 “cout“、“name”:未知重寫說明

    在C++編程中,未定義標(biāo)識符"string"、"cout"錯誤多因缺少頭文件引入造成,而"name":未知重寫說明符錯誤則是未正確重寫基類成員函數(shù),解決未定義標(biāo)識符錯誤需正確引入<string>和<iostream>頭文件,對于未知重寫說明符錯誤
    2024-09-09
  • pcl1.8.0+vs2013環(huán)境配置超詳細(xì)教程

    pcl1.8.0+vs2013環(huán)境配置超詳細(xì)教程

    這篇文章主要介紹了pcl1.8.0+vs2013環(huán)境配置超詳細(xì)教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07
  • C++中范圍(Ranges)與視圖(Views)的常見問題、易錯點(diǎn)

    C++中范圍(Ranges)與視圖(Views)的常見問題、易錯點(diǎn)

    ranges和views是C20引入的重要特性,它們讓代碼更加簡潔、高效且富有表達(dá)力,通過理解其基本概念、注意常見的陷阱,并合理應(yīng)用高級技巧,開發(fā)者可以充分利用這些新特性,提升軟件質(zhì)量和開發(fā)效率,,本文將深入淺出地探討ranges與views的基礎(chǔ)概念、常見問題、易錯點(diǎn)及避免策略
    2024-06-06
  • C++使用tinyxml庫處理XML文件

    C++使用tinyxml庫處理XML文件

    TinyXML是一個開源的解析XML的解析庫,能夠用于C++,能夠在Windows或Linux中編譯,這個解析庫的模型通過解析XML文件,然后在內(nèi)存中生成DOM模型,從而讓我們很方便的遍歷這棵XML樹,本文為大家介紹的是使用tinyxml庫處理XML文件,需要的可以參考一下
    2023-07-07
  • c語言swap(a,b)值交換的4種實現(xiàn)方法

    c語言swap(a,b)值交換的4種實現(xiàn)方法

    c語言swap(a,b)值交換的4種實現(xiàn)方法,這么好的東西,盡管簡單,但值得發(fā)表,以此共享。
    2013-02-02
  • C++ Custom Control控件向父窗體發(fā)送對應(yīng)的消息

    C++ Custom Control控件向父窗體發(fā)送對應(yīng)的消息

    這篇文章主要介紹了C++ Custom Control控件向父窗體發(fā)送對應(yīng)的消息的相關(guān)資料,需要的朋友可以參考下
    2015-06-06
  • C++全密碼生成的實現(xiàn)代碼

    C++全密碼生成的實現(xiàn)代碼

    這篇文章主要為大家詳細(xì)介紹了C++全密碼生成的實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • 對稱矩陣的壓縮儲存講解

    對稱矩陣的壓縮儲存講解

    今天小編就為大家分享一篇關(guān)于對稱矩陣的壓縮儲存講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • C++ Boost Thread線程使用示例詳解

    C++ Boost Thread線程使用示例詳解

    Boost是為C++語言標(biāo)準(zhǔn)庫提供擴(kuò)展的一些C++程序庫的總稱。Boost庫是一個可移植、提供源代碼的C++庫,作為標(biāo)準(zhǔn)庫的后備,是C++標(biāo)準(zhǔn)化進(jìn)程的開發(fā)引擎之一,是為C++語言標(biāo)準(zhǔn)庫提供擴(kuò)展的一些C++程序庫的總稱
    2022-11-11

最新評論