【题目描述】
阿克曼(Ackmann)函数中,定义域是非负整数,函数值定义为:
【输入】
输入和。
【输出】
函数值。
【输入样例】
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;
}