题目网址
【题目描述】
阿克曼(Ackmann)函数A(m,n)中,m,n定义域是非负整数(m≤3,n≤10),函数值定义为:
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时)
【输入】
输入m和n。
【输出】
函数值。
【输入样例】
2 3
【输出样例】
9
分析:没什么好说的,代入一下
这里我用了递归算法,是有返回值的
#include<iostream>
#include<cstdio>
using namespace std;
int n,m;
int akm(int m,int n)
{
if(m==0) return n+1;
if(m>0&&n==0) return akm(m-1,1);
if(m>0&&n>0) return akm(m-1,akm(m,n-1));
}
int main()
{
cin>>m>>n;
cout<<akm(m,n);
return 0;
}
谢谢支持!