【题目描述】
阿克曼(Ackmann)函数A(m,n)A(m,n)中,m,nm,n定义域是非负整数(m≤3,n≤10)(m≤3,n≤10),函数值定义为:
akm(m,n)=⎧⎩⎨n+1akm(m−1,1)akm(m−1,akm(m,n−1))(m=0时)(m>0,n=0时)(m,n>0时)akm(m,n)={n+1(m=0时)akm(m−1,1)(m>0,n=0时)akm(m−1,akm(m,n−1))(m,n>0时)
【输入】
输入mm和nn。
【输出】
函数值。
【输入样例】
2 3
【输出样例】
9
这题是标准的递归形式:因为给出数学表达式,然后我们可以直接写函数表达式来完这个表达式
再次理解递归吧:
比如这题: 首先我们要知道函数表达式的知识,在返回值不是void的函数中,return 返回的是这个函数最后的结果的值,同 样递归函数也是一个函数,只是它是调用自身的函数而已,所以不要迷这点,因为递归函数也不是一个非常高大上 的东西
在else 中 return 返回的值是akm(m-1,akm(m,n-1))递归完成以后的,有可能会递归调动很多层,所以不要总想着每次返回这样的思想,
在if 中 return 就是返回当 m==0的值这个函数的值n+1,注意函数 return 的真正用意
再者这题很简单
#include<bits/stdc++.h>
using namespace std;
int akm(int m,int n)
{
if(m==0)
return n+1;
else if(m>0&&n==0)
return akm(m-1,1);
else
return akm(m-1,akm(m,n-1));
}
int main()
{
int m,n;
cin>>m>>n;
akm(m,n);
cout<<akm(m,n)<<endl;
return 0;
}