问题及代码:
/*
*Copyright (c) 2014,烟台大学计算机学院
*All rights reserved.
*文件名称:莉莉.cpp
*作者:李莉
*完成日期:2014年12月27日
*版本号:v1.0
*
*问题描述:一个简单的计算,你需要计算f(m,n),其定义如下: 当m=1时,f(m,n)=n; 当n=1时,f(m,n)=m; 当m>1,n>1时,f(m,n)= f(m-1,n)+ f(m,n-1)
输入第一行包含一个整数T(1<=T<=100),表示下面的数据组数。 以下T行,其中每组数据有两个整数m,n(1<=m,n<=2000),中间用空格隔开。
*程序输入:输入要处理的数的组数以及每组数
*程序输出:每组数计算的结果
*/
#include <iostream>
using namespace std;
int f(int x,int y);
int main()
{
int n,a,b,i;
cin>>n;
for(i=0;i<n;i++)
{
cin>>a>>b;
cout<<f(a,b)<<endl;
}
return 0;
}
int f(int x,int y)
{
if(x==1)
return y;
else if(y==1)
return x;
else
return (f(x-1,y)+f(x,y-1));
}
心得体会:再次熟悉递归。。。练练手