using System; using System.Collections.Generic; using System.Linq; using System.Text;
namespace MyExample_Hanoi_ { class Program { static void Main(string[] args) { HanoiCalculator c = new HanoiCalculator(); Console.WriteLine(c.CalculateHanoi(64));//括号内可更改盘数 } }
class HanoiCalculator { public ulong CalculateHanoi(int count)//count:盘子数 { ulong stepForOnlyCurrentDish = 1;//搬动一个盘子只需要1步 if (count == 1) { return stepForOnlyCurrentDish;//汉诺塔至少要一个盘子 } ulong totalSteps = stepForOnlyCurrentDish + CalculateHanoi(count - 1)*2;//stepForOnlyCurrentDish搬动“最后一个”大盘子“只要一步+这个大盘子之上的那些盘子要构成汉诺塔所需步数(使用递归)+再把那些盘子搬回来 return totalSteps; } } }
//这个例子是猛哥(刘铁猛)(也算是我的正式老师)讲的,注释部分我根据自己的理解加了一些,和网友们一起交流,共同进步!; |