试着用回溯法解,推理题,八皇后问题,解数独

试着用回溯法解,推理题,八皇后问题,解数独因为是一类问题就都写一个类里了

#include stdio.h
class TuiLi //推理类

//私有方法部分
protected: 

SYSTEMTIME TIME; //标准系统时间存放结构体共8个成员16字节

struct FZ
{
int ys;
int yp;
int gj;
int cw;
int yl;
};//房子属性结构体

FZ Fz[5];//定义5间房子
int Biao[120][5];//定义组合表
int gj,ys,yl,cw,yp;//组合标志
int sz[25];

//解数独用
int sudu[81]; //记录回溯路径用
bool sudu_ji[81]; //用于标记已经被题目标示出来的值
int SD[9][9]; //数独棋盘

//解N皇后问题
int N;//用于输入皇后问题的解题规模本例子因为内存分配只能解33皇后以类的问题更改内存分配大小可以增大解题规模
int hh[1024]; //记录回溯路径用最多用于解33皇后问题
int HH[33][33];//皇后问题棋盘

//公共方法部分 
public:
TuiLi(void); 
~TuiLi(void);
void init_biao(void);//初始化组合表
void print(void);//屏幕输出
void gx(void);//刷新推理结果
int OK(void);//推理剪枝条件
int go(void);//推理题主入口方法

int ok_sd(void);//数独剪枝条件
int go_sd(void);//解数独人口点
void sd_in(void);//棋盘数据输入
void SD_in(void);//获取题目信息
void sd_out(void);//棋盘数据输出
void sd_print(void);//屏幕输出结果

int ok_hh(int m);//皇后问题剪枝函数
int ok_hh_sc(void);//最后检测
int go_hh(void); //皇后问题入口点
void hh_init(void);//初始化棋盘数据
void hh_out(void);//棋盘数据刷新
void hh_print(void);//输出结果

};

永不止步步 发表于11-14 10:26 浏览65535次
分享到:

已有0条评论

暂时还没有回复哟,快来抢沙发吧

添加一条新评论

只有登录用户才能评论,请先登录注册哦!

话题作者

永不止步步
金币:67410个|学分:308217个
立即注册
畅学电子网,带你进入电子开发学习世界
专业电子工程技术学习交流社区,加入畅学一起充电加油吧!

x

畅学电子网订阅号