有5个人,第5个人比第4个人大2岁,第4个人比第3个人大2岁,第3个人比第2个人大2岁,第2个人比第1个人大2岁,第1个人说他10岁。求第5个人多少岁。如果age(n)为第n个人的岁数,此函数可如下定义:
A: 当n=1,age(n)=10当n>1时,age(n)=age(n-1)+2
B: 当n>=1,age(n)=age(n-1)+2
C: 当n=5,age(n)=10当n>=1,age(n)=age(n+1)-2
D: 当n=5,age(n)=2当n>=1,age(n)=age(n-1)+2
A: 当n=1,age(n)=10当n>1时,age(n)=age(n-1)+2
B: 当n>=1,age(n)=age(n-1)+2
C: 当n=5,age(n)=10当n>=1,age(n)=age(n+1)-2
D: 当n=5,age(n)=2当n>=1,age(n)=age(n-1)+2
举一反三
- 有5个人,第5个人比第4个人大2岁,第4个人比第3个人大2岁,第3个人比第2个人大2岁,第2个人比第1个人大2岁,第1个人说他10岁。求第5个人多少岁。如果age(n)为第n个人的岁数,此函数可如下定义:
- 【改错题】 2.以下程序的功能是:有5个人坐在一起,问第5个人的岁数,他说比第4个人大2岁。问第4个人的岁数,他说比第3个人大2岁。问第3个人的岁数,他说比第2个人大2岁。问第2个人的岁数,他说比第1个人大2岁.最后问第1个人,他说是10岁。请问第5个人多大? #include [stdio.h] int age(int n) { int c; if(n=1) c=10; else c=age(n)+2; return c; } void main() { printf("%d\n",age5); }
- 有n个人坐在一起,问第n个人多少岁,他说比第n-1个人大两岁,问第n-1个人多少岁,他说比第n-2个人大两岁,以此类推,问第2个人多少岁,他说比第1个人大两岁,最后问第1个人多少岁?他说是10岁。使用函数的递归调用求第n个人多少岁
- 请对课堂讲的年龄递归问题画两张图:第一图回溯递推过程第二图递归实现过程求年龄。有5个人坐在一起。问第5个人多少岁?他说比第4个人大2岁。问第4个人多少岁?他说比第3个人大2岁。问第3个人,他说比第2个人大2岁。问第2个人,他说比第1个人大2岁。问第1个人,说是10岁。/*案例代码文件名:ch6_6.c*/#include <;stdio.h>;age (int n){ int c;if (n==1) c=10;else c=age(n-1)+2;return(c);}main(){printf(“the fifth person’s age is %d”,age(5));}
- 题目:有5个人坐在一起,问第五个人多少岁?他说比第四个人大两岁。问第四个人岁数,他说比第三个人大两岁。问第三个人,又说比第二个人大两岁。问第二个人,说比第二个人大两岁。最后问第一个,他说是十岁。请问第五个人多大? [br][/br] ''' 需求:有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第3个人大2岁。问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁。最后问第一个人,他说是10岁。请问第五个人多大? 思路:利用递归的方法,递归分为回推和递推两个阶段。要想知道第五个人岁数,需知道第四人的岁数,依次类推,推到第一人(10岁),再往回推。 ''' def age(n): if n == 1: c = 10 else: ______________ return c print age(5) A: c = age(n-1) + 2 B: c = age(n-1) + 1 C: c = age(n-1) -1 D: c = age(n) + 2