八数码问题的三种算法解答(C#源代码) (补充)

上一篇文章忘了贴八数码问题的数据结构,这里补充一下:

 

using  System;

namespace  Eight_Num_Fengart
{
    
/// <summary>
    
/// 空格移动的方向
    
/// </summary>

    enum Direction
    
{
        None,
        Up,
        Left,
        Right,
        Down
    }


    
/// <summary>
    
/// 解答
    
/// </summary>

    enum Answer
    
{
        
/// <summary>
        
/// 不存在解答
        
/// </summary>

        NotExist,
        
/// <summary>
        
/// 存在解答
        
/// </summary>

        Exist,
        
/// <summary>
        
/// 在当前指定的搜索深度内不存在解答(需要扩大深度)
        
/// </summary>

        NotExistInDepth
    }


    
/// <summary>
    
/// 局面状态信息
    
/// </summary>

    class StateMsg
    
{
        
private int depth;
        
private Direction dir;
        
public int Depth
        
{
            
get return depth; }
        }

        
public Direction Dir
        
{
            
get return dir; }
        }


        
public StateMsg(int depth, Direction dir)
        
{
            
this.depth = depth;
            
this.dir = dir;
        }

    }


    
/// <summary>
    
/// 局面状态
    
/// </summary>

    class State : StateMsg
    
{
        
private long code;

        
/// <summary>
        
/// 棋盘的编码
        
/// </summary>

        public long Code
        
{
            
get return code; }
            
set { code = value; }
        }


        
public State(long code, int depth, Direction dir)
            : 
base(depth, dir)
        
{
            
this.code = code;
        }

    }



}

详细工程文件的下载地址: http://download.csdn.net/source/195320

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值