栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C# > C#教程

C#解决汉诺塔问题DEMO

C#教程 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C#解决汉诺塔问题DEMO

汉诺塔问题是学习递归的入门问题,这里用C#简单实现了一个汉诺塔之间传递盘子的小程序

通过简单绘图实现盘子在几个塔之间的转换:

namespace 汉诺塔
{
  //盘子类
  class HanioItem
  {
    public int HanoiItemHeight { get; set; }//盘子的高度
    public int HanoiItemWidth { get; set; }//盘子的宽度
    public Point HanoiItemPoint { get; set; }//画盘子的起始点
  }
}

namespace 汉诺塔
{   
  public partial class FrmShow : Form
  {

    List HanioItemsA = new List();//塔A中的盘子集合
    List HanioItemsB = new List();//塔B中的盘子集合
    List HanioItemsC = new List();//塔C中的盘子集合
    Pen p;//画笔
    Graphics hanioPicA;//塔A的画布
    Graphics hanioPicB;//塔B的画布
    Graphics hanioPicC;//塔C的画布    
    int tag;//盘子个数    
  
    public FrmShow()
    {      
      InitializeComponent();     
    }

    /// 
    /// 初始化3个PictureBox画布
    /// 
    public void InitialTools()
    {     
p = new Pen(Color.Black);
hanioPicA = HanoiPicA.CreateGraphics();
hanioPicB = HanoiPicB.CreateGraphics();
hanioPicC = HanoiPicC.CreateGraphics();
    }
      
    public void InitialGraphics()
    {
      int HanioItemHeight = 15;//塔中盘子的高度
      int HanioStartItemWidth = 90;//第一个盘子的宽
      Point HanioStartItemP = new Point(15, 135);//第一个盘子起始点

      InitialTools();   
      tag = Convert.ToInt16(this.Tag.ToString());

      HanioItemsA.Clear();
      HanioItemsB.Clear();
      HanioItemsC.Clear();

    
      //初始化塔A上的盘子     
      int diffrence = (90 - 30) / tag;//两个盘子之间宽度之差

      for (int i = 1; i <= tag; i++)
      {
 HanioItem item = new HanioItem();
 item.HanoiItemWidth = HanioStartItemWidth;
 item.HanoiItemHeight = HanioItemHeight;
 item.HanoiItemPoint = HanioStartItemP;
 HanioItemsA.Add(item);

 HanioStartItemWidth -= diffrence;
 HanioStartItemP.X += diffrence / 2;
      }

      //为汉诺塔画盘子
      ShowHanoiGraphics();
    }

    /// 
    /// 画3个塔中的盘子
    /// 
    private void ShowHanoiGraphics()
    {      
      hanioPicA.Clear(this.BackColor);
      hanioPicB.Clear(this.BackColor);
      hanioPicC.Clear(this.BackColor);

      //为汉诺塔A画初始线条      
      hanioPicA.DrawLine(p, 0, 150, 120, 150);
      hanioPicA.DrawLine(p, 60, 0, 60, 150);

      //为汉诺塔B画初始线条     
      hanioPicB.DrawLine(p, 0, 150, 120, 150);
      hanioPicB.DrawLine(p, 60, 0, 60, 150);

      //为汉诺塔C画初始线条      
      hanioPicC.DrawLine(p, 0, 150, 120, 150);
      hanioPicC.DrawLine(p, 60, 0, 60, 150);

      //画A塔的盘子
      for (int i = 0; i < HanioItemsA.Count; i++) 
      {
 hanioPicA.DrawRectangle(p, HanioItemsA[i].HanoiItemPoint.X, HanioItemsA[i].HanoiItemPoint.Y - i * 15, HanioItemsA[i].HanoiItemWidth, HanioItemsA[i].HanoiItemHeight);
      }
     
      //画B塔的盘子
      for (int i = 0; i < HanioItemsB.Count; i++)
      {
 hanioPicB.DrawRectangle(p, HanioItemsB[i].HanoiItemPoint.X, HanioItemsB[i].HanoiItemPoint.Y - i * 15, HanioItemsB[i].HanoiItemWidth, HanioItemsB[i].HanoiItemHeight);
      }
     
      //画C塔的盘子
      for (int i = 0; i < HanioItemsC.Count; i++)
      {
 hanioPicC.DrawRectangle(p, HanioItemsC[i].HanoiItemPoint.X, HanioItemsC[i].HanoiItemPoint.Y - i * 15, HanioItemsC[i].HanoiItemWidth, HanioItemsC[i].HanoiItemHeight);
      }
     
    }

    /// 
    /// 汉诺塔核心递归函数
    /// 
    /// 盘子个数
    /// 塔A
    /// 塔B
    /// 塔C
    private void Hanio(int n, List A, List B, List C)
    {
      if (n == 1)
      {
 HanioMove(A, C);
      }

      else
      {
 Hanio(n - 1, A, C, B);
 HanioMove(A, C);
 Hanio(n-1,B,A,C);
      }
    }
    
    /// 
    /// 盘子移动画图实现
    ///    
    private void HanioMove(List X, List Y)
    { 
      HanioItem item = new HanioItem();
      item = X[X.Count-1];
      X.Remove(item);//塔X移除一个盘子
      Y.Add(item); //塔Y添加一个盘子      
      ShowHanoiGraphics();
      System.Threading.Thread.Sleep(1000);  
    }

    private void btnOK_Click(object sender, EventArgs e)
    {     
      Hanio(tag, HanioItemsA, HanioItemsB, HanioItemsC);
    }

    private void FrmShow_Paint(object sender, PaintEventArgs e)
    {  
      InitialGraphics();
    }      
  }
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/125239.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号