日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

递归函数的例子python卖鸭子_递归算法实现卖鸭子

發布時間:2023/12/16 python 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 递归函数的例子python卖鸭子_递归算法实现卖鸭子 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

問題重述:

1.一個人趕著鴨子去每個村莊賣,每經過一個村子賣去所趕鴨子的一半又一只。這樣他經過了七個村子后還剩兩只鴨子,問他出發時共趕多少只鴨子?經過每個村子賣出多少只鴨子?

代碼:

題目分析:

設在經過n

個村子時有xn

只鴨子,根據題意可以得到如下遞推公式:

則在第n+1

個村子時有xn-xn2+1=xn2-1

只鴨子,即

xn+1=xn2-1

,所以xn-1=xn+1×2

在經過第7個村子書還剩下2只鴨子,即

x7=2

算法構造:

根據上述公式可以看出:

函數出口為: x7=2

函數體為:xn-1=xn+1×2

用最后的鴨子數倒推上一步的鴨子數,再以此類推,在經過最后一個村子時只剩下2兩只鴨子,每遞歸一次經過的村次數就減少一個,直到最后為0即跳出函數

算法實現:

#include

using namespace std;

/*

Auther:Qiaoxue Zheng

Date:2018/11/15

Discribtion:To calculate how many duck the man have

when he sold hal of ducks and one more acrosss a village

and he only have two ducks when across 7 villages

*/

/*

Function:get the number of ducks when he passed count villages

Parameter:

count: the number of villages

*/

int saleDuck(int count) {

if (count == 0) {//exit,only two ducks left at last

return 2;

}

else {//body,get the number of ducks at the last time

count--;

return (saleDuck(count) + 1) * 2;

}

}

//Main function

int main() {

int acount_duck = 0;

int acount_village = 7;

acount_duck = saleDuck(acount_village);

cout <<"一共趕了"<

int all = 0;//the number of all ducks

int sale = 0;//the number of sold ducks

int rest = 0;//the number of rest ducks

//get the numbe of ducks when the man passed every village

for (int count = 7; count >= 1; count--) {

all = saleDuck(count);

sale = all / 2 + 1;

rest = all - sale;

cout << "經過第" << 8 - count << "個村莊時賣了" << sale << "只鴨子,還剩" << rest << "只鴨子" << endl;

}

system("pause");

return 0;

}

運行結果:

總結

以上是生活随笔為你收集整理的递归函数的例子python卖鸭子_递归算法实现卖鸭子的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。