题目来自于严蔚敏《数据结构》,参考伪代码实现的程序:

 #include <stdio.h>
#include <malloc.h>
//记录通道块在迷宫矩阵当中的横、纵坐标
struct Position{
int x;
int y;
};
//放入栈当中的通道块元素
struct SElement {
int ord;//记录此通道块在整个通道当中的次序
Position p;//记录此通道块在矩阵当中的位置
int di;//记录下一次测试这一路径的临近路径的位置
};
//创建栈数据结构
#define STACK_INIT_SIZE 100
#define STACKINCREMENT 10
struct MyStack{
SElement* base;
SElement* top;
int stacksize;
};
//创建一个栈如果创建成功则返回1,否则就返回0
int InitStack(MyStack* s)
{
s->base=(SElement*)malloc(STACK_INIT_SIZE*sizeof(SElement));//为栈分配初始空间
if(!s->base) return ;
s->top=s->base;//设定为空栈
s->stacksize=STACK_INIT_SIZE;
return ;
}
//判断栈是否为空,如果是空的就返回0,否则就返回1
int IsStackEmpty(MyStack* s)
{
if(s->top==s->base) return true;
return false;
}
//获取栈顶元素,如果栈为空就返回0 否则就返回1
int GetTop(MyStack* s,SElement* e)
{
if(IsStackEmpty(s)) return ;
e=s->top-;
return ;
}
//获取栈的长度,并且通过程序返回
int StackLength(MyStack* s)
{
return s->top-s->base;
}
//插入元素e为新的栈顶元素,插入成功则返回1,否则返回0
int Push(MyStack* s,SElement e)
{
if(s->top-s->base>=STACK_INIT_SIZE)
{
s->base=(SElement*)realloc(s->base,(s->stacksize+STACKINCREMENT)*sizeof(SElement));
if(!s->base) return ;
s->top=s->base+s->stacksize;
s->stacksize+=STACKINCREMENT;
}
*(s->top)=e;
s->top++;
return ;
}
//弹出栈顶元素赋值给e弹出成功返回1,弹出失败返回0
int Pop(MyStack* s,SElement* e)
{
if(IsStackEmpty(s)) return ;
*e=*(s->top-);
s->top--;
return ;
}
//定义墙元素为2 可走路径为0 已知路径为curStep 不能够通过的路径为-1
#define MazeScale 10
int Maze[MazeScale][MazeScale]={{,,,,,,,,,},{,,,,,,,,,},{,,,,,,,,,},{,,,,,,,,,},
{,,,,,,,,,},{,,,,,,,,,},{,,,,,,,,,},{,,,,,,,,,},{,,,,,,,,,},{,,,,,,,,,}};
//辅助函数考察当前路径能否通过
bool Pass(Position posi)
{
//只有路径所在位置的数字为0的是可以走的
if(Maze[posi.x][posi.y]==)
{
return true;
}
return false;
}
//按顺时针方向从东开始寻找矩阵当中某一个位置的临近位置
Position NextPosition(Position now,int direction)
{
Position next;
int x=now.x;
int y=now.y;
switch(direction)
{
//东
case :{
next.x=x;
next.y=y+;
break;
}
//南
case :{
next.x=x+;
next.y=y;
break;
}
//西
case :{
next.x=x;
next.y=y-;
break;
}
//北
case :
{
next.x=x-;
next.y=y;
break;
}
default:break;
}
return next;
}
//留下足迹
void FootPrint(Position p,int step)
{
Maze[p.x][p.y]=step;
}
//路径不可走的话就留下-1的标记
void MarkPrint(Position p)
{
Maze[p.x][p.y]=-;
}
int main()
{
//打印出迷宫矩阵
for(int i=;i<MazeScale;i++)
{
for(int j=;j<MazeScale;j++)
{
printf("%d ",Maze[i][j]);
}
printf("\n");
}
//迷宫程序主体
MyStack path;//记录路径的栈
InitStack(&path);//初始化路径数组
Position curp;//当前被试位置
//初始化当前位置为矩阵入口
curp.x=;
curp.y=;
int curStep=;//被探索的步数
do
{
if(Pass(curp))
{
FootPrint(curp,curStep);//可走就在迷宫里面留下足迹
//创建一个栈元素,存储可行路径的相关值,将这个元素存储到栈当中
SElement e;
e.di=;//意味着下一个被试路块为这一个路块的正上方的路块
e.ord=curStep;
e.p.x=curp.x;
e.p.y=curp.y;
Push(&path,e);//将路径块入栈
if(curp.x==MazeScale- && curp.y==MazeScale-) break; //如果被压入的路径块到了迷宫的终点就退出循环
//找到下一个被试块
curp=NextPosition(curp,);//找到前一个被试块东面的路径块作为被试块
curStep++;//被探索的步数加一
}else//如果当前被试路径不能够通过的话
{
if(!IsStackEmpty(&path))
{
SElement e;
Pop(&path,&e);
curStep--;
//将这一段所有的周围路径都已经被测试过的路径从栈中清除
while(e.di== && !IsStackEmpty(&path)){
MarkPrint(e.p);
Pop(&path,&e);
curStep--;
}
//如果当前栈顶还有未被测试的路径就测试剩余的周围路径
if(e.di<)
{
curp=NextPosition(e.p,e.di+);
e.di++;
curStep++;
Push(&path,e);
}
}
}
}while(!IsStackEmpty(&path));
printf("\n");
//打印出结果迷宫矩阵
for(int i=;i<MazeScale;i++)
{
for(int j=;j<MazeScale;j++)
{
printf("%d ",Maze[i][j]);
}
printf("\n");
}
return ;
}

应用栈解决迷宫问题的C语言实现的更多相关文章

  1. 递归转手工栈处理的一般式[C语言]

    是任意形式的递归,是化解的一般式. 主题所谓的“递归调用化解为栈处理”,意思是,将递归函数调用化解为“一个由stack_push stack_pop stack_top等函数调用组成的循环式子”.这里 ...

  2. 有关dfs、bfs解决迷宫问题的个人见解

    可以使用BFS或者DFS方法解决的迷宫问题! 题目如下: kotori在一个n*m迷宫里,迷宫的最外层被岩浆淹没,无法涉足,迷宫内有k个出口.kotori只能上下左右四个方向移动.她想知道有多少出口是 ...

  3. 【Java EE 学习 69 上】【struts2】【paramsPrepareParamsStack拦截器栈解决model对象和属性赋值冲突问题】

    昨天有同学问我问题,他告诉我他的Action中的一个属性明明提供了get/set方法,但是在方法中却获取不到表单中传递过来的值.代码如下(简化后的代码) public class UserAction ...

  4. 用栈解决Largest Rectangle问题

    一问题描述 Given n non-negative integers representing the histogram's bar height where the width of each ...

  5. hdu 3666(差分约束,手动栈解决超时问题)

    THE MATRIX PROBLEM Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Other ...

  6. 用C语言解决迷宫问题

    #include <stdio.h> #include <stdlib.h> #define ROW 10 #define COL 10 /*迷宫中位置信息*/ typedef ...

  7. 利用顺序栈解决括号匹配问题(c++)-- 数据结构

    题目: 7-1 括号匹配 (30 分)   给定一串字符,不超过100个字符,可能包括括号.数字.字母.标点符号.空格,编程检查这一串字符中的( ) ,[ ],{ }是否匹配. 输入格式: 输入在一行 ...

  8. 刁肥宅详解中缀表达式求值问题:C++实现顺序/链栈解决

    1. 表达式的种类 如何将表达式翻译成能够正确求值的指令序列,是语言处理程序要解决的基本问题,作为栈的应用事例,下面介绍表达式的求值过程. 任何一个表达式都是由操作数(亦称运算对象).操作符(亦称运算 ...

  9. 两个栈实现一个队列,C语言实现,队列可伸缩,容纳任意数目的元素。

    一.思路:1.创建两个空栈A和B:2.A栈作为队列的入口,B栈作为队列的出口:3.入队列操作:即是入栈A:4.出队列操作:若栈B为空,则将A栈内容出栈并压人B栈,再出 B栈:不为空就直接出栈: 二.代 ...

随机推荐

  1. 简单解决“ORA-27100: shared memory realm already exists”的问题

    背景 看到这篇文章,算是当初记录过程的一篇了,不像别的,只是有个结果算火.只是感觉到现在可能是碰不见这个问题了,现在哪有32位的oracle啊.可见技术随着岁月的变化,真不知10年后再看今天的问题,可 ...

  2. VS C# xamarin 开发android 调试正常 发布分发后运行闪退出错

    我强烈推荐大家如果不是很有必要就不要引用一些.NET STD的库,比如json库newtonsoft.JSON,直接引用官方的system.Json就足够了,否则会导致体积变得巨大 好了废话不多说,这 ...

  3. 配置spring所需要的jar包

    spring.jar是包含有完整发布的单个jar 包,spring.jar中包含除了spring-mock.jar里所包含的内容外其它所有jar包的内容,因为只有在开发环境下才会用到 spring-m ...

  4. PYTHON-面向对象 继承 派生

    1. 什么是继承 继承是一种新建类的方式,新建的类称之为子类/派生类,被继承的类称之为父类/基类/超类 继承有3个特点: 1. 子类可以遗传/重用父类的属性(解决类与类之间代码冗余的问题) 2. 在p ...

  5. 测试开发之前端——No7.HTML5中的鼠标事件

    鼠标事件 由鼠标或相似的用户动作触发的事件. 适用于所有 HTML 5 元素: 属性 值 描述 onclick script 当单击鼠标时运行脚本 ondblclick script 当双击鼠标时运行 ...

  6. hdu2838树状数组解逆序

    离散化和排序后的序号问题搞得我实在是头痛 不过树状数组解逆序和偏序一类问题真的好用 更新:hdu的数据弱的真实,我交上去错的代价也对了.. 下面的代码是错的 /* 每个点的贡献度=权值*在这个点之前的 ...

  7. spring配置redis注解缓存

    前几天在spring整合Redis的时候使用了手动的方式,也就是可以手动的向redis添加缓存与清除缓存,参考:http://www.cnblogs.com/qlqwjy/p/8562703.html ...

  8. CSP 地铁修建 Kruskal (最小生成树+并查集)

    问题描述 A市有n个交通枢纽,其中1号和n号非常重要,为了加强运输能力,A市决定在1号到n号枢纽间修建一条地铁. 地铁由很多段隧道组成,每段隧道连接两个交通枢纽.经过勘探,有m段隧道作为候选,两个交通 ...

  9. 在vs2008工程中制作cab包

    内容转自MSDN 1.首先,制作自己的智能设备工程 2.添加cab工程: 为解决方案添加智能设备 CAB 项目 打开现有的智能设备项目,并确保“解决方案资源管理器”可见. 在“文件”菜单上指向“添加” ...

  10. maven的三种工程pom、jar、war

    阅读数:739 maven中的三种工程: 1.pom工程:用在父级工程或聚合工程中.用来做jar包的版本控制. 2.war工程:将会打包成war,发布在服务器上的工程.如网站或服务. 3.jar工程: ...