void hanNuoTa(int n,int a,int b,int c)
{
    if (n == 0) return;
    hanNuoTa(n - 1, a, c, b);
    cout << n <<":"<< a<< "->" << c <<endl;
    hanNuoTa(n - 1, b, a, c);
}

定义 n 代表n个盘子,a,b,c,代表三个柱子的标号

若要将n个盘子从a-》c,需要先将前n-1个盘子从a借助c移到b

然后将第n个盘子从a移到c

然后将前n-1个盘子从b 借助a移到c

从而递归实现,复杂的2^n -1

相关文章:

  • 2022-12-23
  • 2021-06-10
  • 2021-12-20
  • 2021-10-12
  • 2022-01-14
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2021-11-23
  • 2022-12-23
  • 2021-07-08
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案