c语言-C语言迷宫算法,找不出问题在哪

问题描述

C语言迷宫算法,找不出问题在哪

#include
#include
#define M 4
#define N 4
#define MaxSize 20
int mg[M+2][N+2]={
{1,1,1,1,1,1},
{1,0,0,0,1,1},
{1,0,1,0,0,1},
{1,0,0,0,1,1},
{1,0,0,0,0,1},
{1,1,1,1,1,1}
};
struct
{
int i;
int j;
int pre;
}Qu[MaxSize];
int front=-1,rear=-1;
int minlen=0;
int num=1;
void print(int front)
{
int k=front,j;
int ns=0;
do
{
j=k;
k=Qu[k].pre;
ns++;
}while(k!=-1);
if(num==1) minlen=ns;
if(ns==minlen)
{
ns=0;
k=front;
printf("第%d条最短路径(反向输出):
",num++);
do
{
j=k;
printf(" (%d,%d)",Qu[k].i,Qu[k].j);
k=Qu[k].pre;
if(++ns%5==0) printf("
");
}while(k!=-1);
printf("
");
}
}
void mgpath(int x1,int y1,int x2,int y2)
{
int i,j,find=0,di,k;
rear++;
Qu[rear].i=x1;Qu[rear].j=y1;Qu[rear].pre=-1;
while(front!=rear)
{
front++;
for(di=0;di
{
switch(di)
{
case 0:i=Qu[front].i-1;j=Qu[front].j;break;
case 1:i=Qu[front].i;j=Qu[front].j+1;break;
case 2:i=Qu[front].i+1;j=Qu[front].j;break;
case 3:i=Qu[front].i,j=Qu[front].j-1;break;
}
if(i>0&&j>0&&mg[i][j]==0&&(i!=Qu[Qu[front].pre].i||j!=Qu[Qu[front].pre].j))
{
rear++;
Qu[rear].i=i;Qu[rear].j=j;
Qu[rear].pre=front;
}
}
}
for(k=0;k<=rear;k++)
{
if(Qu[k].i==x2&&Qu[k].j==y2)
{
find=1;
print(k);
}
}
if(!find) printf("不存在路径!
");
}
void main()
{
printf("所有迷宫([1,1]->[4,4])最短路径
");
mgpath(1,1,M,N);
}

解决方案

http://www.jb51.net/article/53124.htm

解决方案二:

http://blog.csdn.net/xugang_2001/article/details/1776306

解决方案三:

首先,你这个问题问的属于数据结构方面,涉及到语法错误,或者逻辑错误,但是

你又没有说清楚到底是哪个错误,控制台有没有报错也没有说,如果要给你看,还得给你现找个编译器放里面

解决方案四:

迷宫算法(c语言实现)
回溯算法----C语言 迷宫问题

时间: 2025-01-28 00:16:09

c语言-C语言迷宫算法,找不出问题在哪的相关文章

win7如何更改语言 电脑语言改成英文的方法

今年evad3rs团队发布的iOS 7完美越狱工具有些特殊,中国版iOS7完美越狱工具中,捆绑有太极助手插件,此插件类似流氓插件,容易导致iOS越狱设备出现白苹果现象(国外版无此插件).目前比较好的解决办法是:在使用电脑中越狱的时候,将电脑语言改为英文,可绕过该插件.但很多电脑小白用户还不知道如何更改电脑语言,因此本文将为大家详细介绍下电脑语言更改教程. 如何更改电脑语言 电脑语言改为英文方法 以下笔者以Windows 7系统截图演示,教大家如何更改电脑语言.其他XP或者Win8系统设置方法与此

c语言-C语言递归的内存释放问题

问题描述 C语言递归的内存释放问题 我用C语言实现alpha-beta极小极大算法来做一个棋类游戏的AI,博弈树是用递归的方式构造的,然后发现AI每下一步程序的内存都在增大,原来是因为递归没有释放内存. 耗内存的指针是棋盘 char ** chessboard; 于是我在递归函数的每一个return之前都把 chessboard 给释放了,发现内存还是一直在涨,求解.. 解决方案 把递归函数实现贴出来. 解决方案二: 估计释放的不全.二级指针要分两级释放. 解决方案三: 二级指针的释放是要分两步

安卓app多语言多语言切换

问题描述 安卓app多语言多语言切换 请问大神们可以帮助我吗?在我的程序里面我想实现多语言切换,调用系统的语言设置, 改变我自己的app语言,但是不改变系统的显示语言,这样怎么实现? 解决方案 http://blog.csdn.net/forrey/article/details/44547813 去这里看看说不定对你有帮助! 解决方案二: http://my.oschina.net/jack1900/blog/290694http://blog.csdn.net/cento123/articl

c语言-C语言实现文件合并的问题

问题描述 C语言实现文件合并的问题 之前已经编写了一个程序,可以实现.txt的文件内容追加写,可是对两个视频操作的时候就行不通了.但是又不知道问题出现在哪里,视频能合并,文件大小是两个文件的和,可是新和成的文件内容只显示一个文件的内容.这个要怎么解决. 解决方案 视频文件不是简单两个文件叠加.视频文件包含复杂的结构,文件头部分指定了这个视频的格式,有多少帧,存储的偏移地址是什么你简单合并两个文件,播放器只知道根据第一个文件的文件头找数据,附加在后面的第二个文件是读不到的.你需要重新编码得到一个完

c语言-C语言的文件问题????????

问题描述 C语言的文件问题???????? 我如果想往C的文件里写入数据,我要事先手动建立一个.txt文件吗?还是有其他方法自动创建? 解决方案 O(NlgK)问题优先队列实现文件C语言C语言中头文件相互包含问题c语言中,文件路径读取问题 解决方案二: 不用手动建立文件的,c语言里有很多文件操作函数,可以自动建立文件,并可以写入你想写入的数据 解决方案三: 我也想提这样的问题.不过既然是C的文件,我觉得应该是创建.C文件吧,.TXT是文本格式的,估计是不行的. 解决方案四: c语言中可以通过代码

c语言-C语言编写扫雷的小白问题

问题描述 C语言编写扫雷的小白问题 #include #include #include #include /*这是一个简单的基于控制台界面的扫雷小游戏*/char display[9][9];/*定义显示用数组display*/char control[9][9];/*定义核心内容数组control*/void output(char a[9][9]);void output1(char a[9][9]);void scan_mine(int xint y);void nine();int n

c语言-C语言相邻数求最大和的问题求解答

问题描述 C语言相邻数求最大和的问题求解答 #include int** matrix(int row) { int** matr; matr = malloc(row*sizeof(int*)); for(int i = 0; i < row; i++) { matr[i] = malloc(row*sizeof(int)); } return matr; } void get_input(int** arrays, int row) { for(int i = 0; i < row; i+

c语言-C语言用递归求圆周率的值,要求精确到小数点后3位,不得使用循环

问题描述 C语言用递归求圆周率的值,要求精确到小数点后3位,不得使用循环 C语言用递归求圆周率的值,要求精确到小数点后3位,不得使用循环 解决方案 http://jingyan.baidu.com/article/bea41d437c69b8b4c51be6e9.html 解决方案二: public class Test { public static void main(String[] args) { System.out.println("怎么插入代码块.."); } }

c语言-C语言 关于用矩形法求定积分

问题描述 C语言 关于用矩形法求定积分 #include""stdio.h""#include""math.h""int main(){ double fun1(double x); double fun2(double x); double fun3(double x); double calc(double adouble bdouble (*p)(double)); int type; double ab; double