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