A.5B7C8D10int foo(int n){if(n <= 2)return n:return foo(n-1)+f(n-2);}
3 回答

暮色呼如
TA貢獻1853條經驗 獲得超9個贊

翻翻過去那場雪
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。
滿意請采納!

白衣非少年
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;
后面的以此類推
添加回答
舉報
0/150
提交
取消