亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

原題如下:當N=5時,下列函數的返回值是:

原題如下:當N=5時,下列函數的返回值是:

當年話下 2023-01-03 17:13:54
A.5B7C8D10int foo(int n){if(n <= 2)return n:return foo(n-1)+f(n-2);}
查看完整描述

3 回答

?
暮色呼如

TA貢獻1853條經驗 獲得超9個贊

這是個遞歸函數。n=5時返回值為8

答案選C


//n的變化 //第一次 return foo(4)+foo(3); //第二次 return foo(3)+foo(2); //因為foo(3)大于2所以還要調用,但后面那個就foo(2)直接返回2,知道foo(2)就返回2 //所以結果=2+2+2+2=8


查看完整回答
反對 回復 2023-01-06
?
翻翻過去那場雪

TA貢獻2065條經驗 獲得超14個贊

這個答案是選C的。
遞歸都是完全可以轉化為數學里面的數列來做的,他們都是有一定規律的。
你仔細看看,就會發現foo(n)= foo(n-1)+f(n-2)。
而當n=1的時候,foo(1)=1
當n=2的時候,foo(2)=2
所以很容易就推出:
foo(3)=foo(2)+foo(1)=2+1=3
foo(4)=foo(3)+foo(2)=3+2=5
foo(5)=foo(4)+foo(3)=5+3=8
所以答案選擇C。
滿意請采納!

查看完整回答
反對 回復 2023-01-06
?
白衣非少年

TA貢獻1155條經驗 獲得超0個贊

這是一個 類似于 斐波那契數列 的數列
當 n <= 2 時,foo(n) = n
當 n > 2 時,foo(n) = foo(n - 1) + foo(n - 2)
所以:
foo(1) = 1;
foo(2) = 2;; 
foo(3) = foo(2) + foo(1) = 3;
foo(4) = foo(3) + foo(2) = 5;
foo(5) = foo(4) + foo(3) = 8;
后面的以此類推

查看完整回答
反對 回復 2023-01-06
  • 3 回答
  • 0 關注
  • 210 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號