【C/C++】阿克曼函数以及其数学的有限边界思维

简介: ## 在递归函数论和涉及集合的并的某些算法的复杂性研究中,有一个起重要作用的递归函数——阿克曼(Ackermann)函数,该函数是由希尔伯特的学生,德国著名数学家威尔海姆·阿克曼于1928年发现的。这是一个图灵机可计算的,但不是原始递归的函数。下面,我们介绍这个经典的递归函数,并给出其相应的计算过程。

## 在递归函数论和涉及集合的并的某些算法的复杂性研究中,有一个起重要作用的递归函数——阿克曼(Ackermann)函数,该函数是由希尔伯特的学生,德国著名数学家威尔海姆·阿克曼于1928年发现的。这是一个图灵机可计算的,但不是原始递归的函数。下面,我们介绍这个经典的递归函数,并给出其相应的计算过程。


公式:

54c0f9378033988a25b5f6dc98c7105d_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5byg5pm66LaF5ZCWLg==,size_20,color_FFFFFF,t_70,g_se,x_16.png


例如:


      A( 1 ,2 )= A ( 0 , A ( 1 , 1 ) )


                          =A ( 0 , A ( 0 , A ( 1 , 0 ) ) )


                          =A ( 0 , A ( 0 , A ( 0 , 1 ) ) )


                          =A ( 0 , A ( 0 , 2 ) )


                          =A ( 0 , 3 )


                           =4


下面我们将用程序对其进行运算;


##递归算法:

#include<stdio.h>
#include<math.h>
using namespace std;
int Ackermann(int m,int n)
{
    if(m==0){
  return n+1;
    }
  else if(n==0){
  return Ackermann(m-1,1);
    }
    else(m>0&&n>0);{
  return Ackermann(m-1,Ackermann(m,n-1));
    }
}
int main(void)
{
  int t=0;
  int a,b;
  printf("please input (a,b):");
  scanf("%d %d",&a,&b);
  t=Ackermann(a,b);
  printf("Ackermann:%d",t);
  return 0;
}

##程序解析:


54348ee056d3b7d1bfd9c8e0f2db699f_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5byg5pm66LaF5ZCWLg==,size_20,color_FFFFFF,t_70,g_se,x_16.png


##输出结果:

7e2566b86b30f22c442f4f82a49ce227_watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5byg5pm66LaF5ZCWLg==,size_20,color_FFFFFF,t_70,g_se,x_16.png

#############################################################################


简单的阿克曼函数:

A (1,0) 2
A (1,1) 3
A (1,2) 4
A (2,0) 3
A (2,1) 5
A (2,2) 7
A (3,0) 5
A (3,1) 13
A (3,2) 29
A (3,3) 61

#############################################################################


【思维的有限边界性——阿克曼函数】


   在上面我们举了A(1,2)这一个简单的数。但当你将这个数变大时,你就会发现计算机很慢才会输出结果或者不再会输出结果,比如A(4,3)这组数。这样超大一类的数早就超出了宇宙的范围,而对于大于 A(4,3) 这样的数,我认为这已经是超出了人类的思维计算极限。这样的数对我们的生活是没有多大意义的,甚至对于科学研究也是难见其意义的,所以我认为一般不对其进行深究,而对其进行一些简单的掌握即可。


##下面我引用一个比较经典的例子来证明这个无穷性:

c2f7e043e5c7ed3eefeb187153fe6ce5_0f6c40c0a7434b10908466c90c5ad8e2.png


目录
相关文章
|
23天前
|
存储 算法 Serverless
【C/C++ 数据结构】深入探索数据结构中算法复杂度:从C++和数学的视角
【C/C++ 数据结构】深入探索数据结构中算法复杂度:从C++和数学的视角
46 0
|
24天前
|
存储 并行计算 前端开发
【C++ 函数 基础教程 第五篇】C++深度解析:函数包裹与异步计算的艺术(二)
【C++ 函数 基础教程 第五篇】C++深度解析:函数包裹与异步计算的艺术
39 1
|
24天前
|
数据安全/隐私保护 C++ 容器
【C++ 函数 基础教程 第五篇】C++深度解析:函数包裹与异步计算的艺术(一)
【C++ 函数 基础教程 第五篇】C++深度解析:函数包裹与异步计算的艺术
46 0
|
27天前
|
设计模式 算法 安全
【C/C++ 关键字 函数说明符 】C++ final关键字(修饰成员函数无法被子类重写覆盖)
【C/C++ 关键字 函数说明符 】C++ final关键字(修饰成员函数无法被子类重写覆盖)
37 1
|
27天前
|
算法 安全 编译器
【C++ 关键字 override】C++ 重写关键字override(强制编译器检查该函数是否覆盖已存在的虚函数)
【C++ 关键字 override】C++ 重写关键字override(强制编译器检查该函数是否覆盖已存在的虚函数)
25 0
|
19天前
|
存储 安全 编译器
【C++】类的六大默认成员函数及其特性(万字详解)
【C++】类的六大默认成员函数及其特性(万字详解)
33 3
|
22天前
|
安全 程序员 C++
【C++ 基本知识】现代C++内存管理:探究std::make_系列函数的力量
【C++ 基本知识】现代C++内存管理:探究std::make_系列函数的力量
96 0
|
24天前
|
存储 安全 编译器
【C++ 函数设计的艺术】深挖 C++ 函数参数的选择 智能指针与 std::optional:最佳实践与陷阱
【C++ 函数设计的艺术】深挖 C++ 函数参数的选择 智能指针与 std::optional:最佳实践与陷阱
106 0
|
24天前
|
安全 算法 编译器
【C++中的const函数】何时与如何正确声明使用C++ const函数(三)
【C++中的const函数】何时与如何正确声明使用C++ const函数
26 0
|
24天前
|
安全 编译器 Linux
【C++中的const函数】何时与如何正确声明使用C++ const函数(二)
【C++中的const函数】何时与如何正确声明使用C++ const函数
27 0