国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發(fā)設計 > 正文

算法設計 之 遞推法

2019-11-11 00:05:44
字體:
來源:轉載
供稿:網(wǎng)友

原文地址http://www.cnblogs.com/liukemng/p/3719385.html

遞推法就是根據(jù)已知條件,分析推導出問題中的聯(lián)系,然后一步一步進行推倒直至得到結果。

根據(jù)具體問題我們需要選擇是正推還是逆推來解決問題。

 

下面先舉一個遞推中的經(jīng)典例子,就是求兔子數(shù)量的問題:

現(xiàn)有一只一個月大的兔子,已知當兔子在第三個月大時每月就可以生下一只小兔子(好吧,就按兔子是無性繁殖的),求一年后兔子的總數(shù)量。

我們根據(jù)問題分析,發(fā)現(xiàn)可以把兔子分三類:一個月大、二個月大、三個或三個以上月大,列表分析:

月份1月大2月大>=3月大
1100
2010
3101
4111
5212
……   

根據(jù)上面圖表分析可知:

下月“一月大”的兔子數(shù)量等于上月“2月大”+上月“>=3月大”的兔子數(shù)量;

下月“二月大”的兔子數(shù)量等于上月“一月大”的兔子數(shù)量;

下月“>=3月大”的兔子數(shù)量等于上月“二月大”+上月“>=3月大”的兔子數(shù)量;

既然分析完問題,代碼就很簡單了:

復制代碼
/// <summary>/// 遞推(正推)計算兔子的數(shù)量/// </summary>public static void ShowRabbitsCount() {    int oneMonthCount = 1;    int twoMonthCount = 0;    int threeOrMoreMonthCount = 0;    for (int month = 2; month <= 12; month++)    {       //臨時存儲上月各種兔子數(shù)量       int PReOneMonthCount = oneMonthCount;       int preTwoMonthCount = twoMonthCount;       int preThreeOrMoreMonthCount = threeOrMoreMonthCount;       //更新本月各種兔子的數(shù)量       oneMonthCount = preTwoMonthCount+preThreeOrMoreMonthCount;       twoMonthCount = preOneMonthCount;       threeOrMoreMonthCount += preTwoMonthCount;       Console.WriteLine(string.Format("第 {0} 個月兔子的總數(shù)為:{1}", month, oneMonthCount + twoMonthCount + threeOrMoreMonthCount));    }}復制代碼

運行結果:

1

 

下面再看一個逆推的例子:

假設有一個人從1月份開始到本年12月初時體重減少到150斤,他每個月增加的體重為當月初體重的2%,每月鍛煉減少的體重為10斤(這里也按這10斤是月底突然減掉的吐舌笑臉),計算此人一月初時的體重。

根據(jù)問題分析:

12月初的體重為150斤,然后: 本月初體重+10=上月初體重*1.02

復制代碼
/// <summary>/// 遞推(逆推)計算開始時的體重/// </summary>public static void ShowWeight(){    double endWeight = 150;    double perMonthReduce = 10;    for (int month = 11; month > 0; month--)    {        double preStartWeight = (endWeight + perMonthReduce) / 1.02;        endWeight = preStartWeight;        Console.WriteLine(string.Format("第 {0} 個月的開始體重為:{1}", month, preStartWeight));    }}復制代碼

運行結果:

2


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 新干县| 德阳市| 资溪县| 屏边| 汾阳市| 屏南县| 商南县| 克什克腾旗| 桂平市| 辽阳市| 巴林左旗| 毕节市| 水富县| 汾阳市| 澄迈县| 鲁山县| 隆尧县| 信丰县| 河曲县| 乌拉特前旗| 柞水县| 房山区| 霞浦县| 肇州县| 京山县| 玉溪市| 隆昌县| 乃东县| 屏东县| 巴彦淖尔市| 武宁县| 电白县| 康平县| 朔州市| 察雅县| 信丰县| 镇平县| 民县| 鄱阳县| 阿拉善右旗| 潍坊市|