我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何使用C++基于栈的深搜算法实现马踏棋盘

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何使用C++基于栈的深搜算法实现马踏棋盘

这篇文章主要介绍如何使用C++基于栈的深搜算法实现马踏棋盘,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

马踏棋盘(基于栈的深搜算法实现)

简单来说,从任意指定方格出发,为马寻找一条走遍棋盘每一格并且只经过一次的一条路径,这就是马踏棋盘的简单描述。

#include <stdio.h>#include <stdlib.h>#define M 8 //行#define N 8 //列 typedef struct snode    //坐标{    int flag;    int x;    int y;}stack;typedef struct node        {    int top;    //记录走了多少步top+1    int flag;  //记录上一步走的方向    stack * p;    //路径栈}LNode; LNode * CreateStacke();        //创建,并初始化void Judge(LNode * s, int chess[][N]); //判断往哪走void Push(LNode * s, stack x);  //入栈操作void Pop(LNode * s); //出栈操作int IsFull(LNode * s); //判满int IsEmpty(LNode * s); //判空 int main(){    int chess[M][N] = {0};        //棋盘    int i, j;  //循环变量    LNode * step;                    //step存的是走的路径        step = CreateStacke();        Judge(step, chess);     for (i = 0; i < N; i++){        for (j = 0; j < M; j++){            printf("%2d ", chess[i][j]);        }        printf("\n");    }     return 0;}LNode * CreateStacke(){    LNode * s = (LNode *)malloc(sizeof(LNode));        if (!s){        printf("内存空间不足!\n");        system("pause");        exit(0);    }    s->p = (stack *)malloc(sizeof(stack) * M * N);    if (!s->p){        printf("内存空间不足!\n");        system("pause");        exit(0);    }    s->top = -1;    // 把top放在栈底    return s;}void Judge(LNode * s, int chess[][N])        {    int ch[8][2] = {                        //马可能走的八个方向                    {1, -2}, { 2, -1},                    {2, 1 }, { 1, 2 },                    {-1, 2}, {-2, 1 },                    {-2, -1},{-1, -2}                };    int i, j = 1, flag = 1;    stack t;     printf("请输入马的初始位置:(%d * %d)\n", M, N);    scanf("%d%d", &t.y, &t.x);    if (t.x <= 0 || t.x > N || t.y <= 0 || t.y > N){        printf("输入的坐标超出范围!\n");        exit(0);    }    t.x--;    t.y--;    chess[t.y][t.x] = 1;                //选择马的第一个落脚点    Push(s, t);    while (s->top < M * N - 1 && s->top != -1){        for (i = 0; i < 8; i++){            t.x = s->p[s->top].x + ch[i][0];            t.y = s->p[s->top].y + ch[i][1];            //如果它的坐标没有超出范围,并且没有走过,则把该路线存入路径栈            if (t.x >= 0 && t.y >= 0 && t.x < N && t.y < M && !chess[t.y][t.x]){                        if(flag){            //没有退回去                    Push(s, t);                    chess[t.y][t.x] = s->top + 1;                    s->p[s->top - 1].flag = i;                    flag = 1;                    break;                }                else{                //退回去了                    if (s->p[s->top].flag < i){        //重新走时,让它的方向不等于原先的方向                        flag = 1;                    }                }            }        }            //如果没有能走的路时,即,所有的路径都超出范围,或者,该位置已经走过了,则,退到上一步,重新选择;        if (i == 8){                    chess[s->p[s->top].y][s->p[s->top].x] = 0;            Pop(s);            flag = 0;        }    }}void Push(LNode * s, stack x){    if (IsFull(s)){        printf("栈上溢,不能进行入栈操作!\n");        exit (0);     }    else{        s->top++;        s->p[s->top] = x;            }}void Pop(LNode * s){    if (IsEmpty(s)){        printf("栈为空,不能进行出栈操作!\n");        exit(0);    }    s->top--;}int IsFull(LNode * s){    if (s->top >= M * N){        return 1;    }    else{        return 0;    }}int IsEmpty(LNode * s){    if (s->top == -1){        return 1;    }    else{        return 0;    }}

以上是“如何使用C++基于栈的深搜算法实现马踏棋盘”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何使用C++基于栈的深搜算法实现马踏棋盘

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何使用C++基于栈的深搜算法实现马踏棋盘

这篇文章主要介绍如何使用C++基于栈的深搜算法实现马踏棋盘,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!马踏棋盘(基于栈的深搜算法实现)简单来说,从任意指定方格出发,为马寻找一条走遍棋盘每一格并且只经过一次的一条路径
2023-06-29

如何使用C/C++实现马踏棋盘算法

这篇文章主要介绍如何使用C/C++实现马踏棋盘算法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体内容如下问题描述:将马随机放在国际象棋的8×8棋盘Board[0~7][0~7]的某个方格中,马按走棋规
2023-06-29

如何使用C++实现马踏棋盘

这篇文章主要介绍如何使用C++实现马踏棋盘,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!马踏棋盘,用1枚马走遍棋盘。我用一个二维数组记录模拟的整个路径,x为列,y为行,以顺时针的方式寻找下一格,算法比较简单,就通过递
2023-06-29

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录