| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 468 人关注过本帖
标题:【自己困在自己的迷宫了。。。。】
只看楼主 加入收藏
蜀山小二V
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2011-12-15
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:3 
【自己困在自己的迷宫了。。。。】
一直都很顺的 为什么这个迷宫成这样了~~~

好心的大大帮帮我吧~~



#include<stdio.h>
#include <iostream.h>
#include <stdlib.h>
#include<windows.h>
#define MaxSize 100  //队列最大值

//-------------------------定义数组、队列、及常量----------------------------------------
struct
{
 int i;   //方块的行数
 int j;   //方块的列数
 int pre;  //前一方块在队列中的下标
}Queue[MaxSize]; //定义顺序队列
int front = 0, rear = 0; //定义对头和队尾指针并置初值0
int maze[20][20];   //迷宫的图的二维数组,其四周要加上均为1的外框,最大只能放下19*19的迷宫
int minlen = 0;    //最短路径长度
int num = 1;    //路径基数
//-----------------------------从队列中输出路径------------------------------------------
void printpath(int front,int N)
{
 int u,v;
 int k = front, j;
 int ns = 0;   //用于计算路径长度
 do
 {
  j = k;
  k = Queue[k].pre;
  ns++;
 }while (k!=-1);  //k!=-1 保证继续循环
 if(num == 1) minlen = ns; //第一条路径就是一条最短路径
 if(ns == minlen)   //找到其他的最短路径(含第一次找到的最短路径)
 {
  ns = 0;
  k = front;
  printf("第%d条最短路径:\n", num++);
  do
  {
   j = k;
   maze[Queue[k].i][Queue[k].j] = -1;
   k = Queue[k].pre;
 
  }while(k != -1);
  for(u=0; u<=N+1; u++)
     {   
   printf("\n\t\t\t\t");
   for(v=0; v<=N+1; v++)
    {
           if(maze[u][v] == -1) printf("◎"),  maze[u][v] = 0;
     else if(maze[u][v]==1) printf("◆");
     else printf(" ");
            
          }
      }
  printf("\n");
 }
}
//------------------------搜索路径为:(x1,y1)->(x2,y2)---------------------------------------------
void mazepath(int x1,int y1,int x2,int y2)
{
 int i, j, find=0, direction, k;
 rear++;
 Queue[rear].i = x1; Queue[rear].j = y1; Queue[rear].pre = -1;      //(x1,y1)入队
 while(front<=rear)              //队列不为空时循环
 {
  front++;                         //出队,由于不是环形队列,该出队元素仍在队列中
  for(direction=0; direction<3; direction++)               //循环扫描各个方位,把把每个可走的方块插入队列中
  {
   switch(direction)
   {
    case 0:i = Queue[front].i-1; j = Queue[front].j;   break;
    case 1:i = Queue[front].i;   j = Queue[front].j+1; break;
          case 2:i = Queue[front].i+1; j = Queue[front].j;   break;
          case 3:i = Queue[front].i;   j = Queue[front].j-1; break;
         
   }
   if((i>0 && j>0) && maze[i][j]==0 &&  //确保(i,j)方块不越界且可走
   (i!=Queue[Queue[front].pre].i || j!=Queue[Queue[front].pre].j)) //避免出现回退
   {
    rear++;   //将该相邻方块插入到队列中
    Queue[rear].i = i;
    Queue[rear].j = j;
    Queue[rear].pre = front;//指向方块中上一个方块的下标
   }
  }
 }
 for (k=0; k<=rear; k++)
 {
  if(
       Queue[k].i==x2  && Queue[k].j==y2)  //找到了出口,输出路径
       {
    find = 1;
        printpath(k, x2);
       }
 }
 if(!find) printf("不存在路径!\n");
}
//----------------------------------------主函数--------------------------------------------
void main()
{
 system("color 3E");  //屏幕及字体颜色
 SetConsoleTitle("迷宫也疯狂!↖(^ω^)↗                   ------老邓制作!");  //屏幕标题
 int r=1, END=1;
    int N, m, n, p=1, q=1;
 int x,y;     /*定义并输出迷宫图*/
 printf("               ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆\n");
 printf("               ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆\n");
 printf("               ☆☆☆                              ☆☆☆\n");
 printf("               ☆☆☆                              ☆☆☆\n");
 printf("               ☆☆☆          老邓疯狂迷宫        ☆☆☆\n");
 printf("               ☆☆☆                              ☆☆☆\n");
 printf("               ☆☆☆                     COME ON! ☆☆☆\n");
 printf("               ☆☆☆                              ☆☆☆\n");
 printf("               ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆\n");
 printf("               ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆\n");
 printf("\n");
 printf("\n");
 printf("\n");
 printf("请设置迷宫(正方形)的大小(输入边长):");
 scanf("%d",&N);
 printf("迷宫大小为%d×%d\n",N,N);
 printf("\t\t\t\t迷宫图如下:\n");
//------------------------------------设置迷宫图-------------------------------------
 for(m=0; m<=N+1; m++)
 {
  for(n=0; n<=N+1; n++)
  {
   if((m==0||m==N+1) || (n==0||n==N+1)) maze[m][n]=1;
   else maze[m][n]=0;
  }
 }
 
//------------------------------------输出迷宫图--------------------------------------
 
 for(x=0; x<=N+1; x++)
 {   
  printf("\n\t\t\t\t");
  for(y=0; y<=N+1; y++)
   {
    if(maze[x][y]==1) printf("◆");
    else printf(" ");
   
   }
 }
   
   
//-------------------------------设置迷宫障碍物-并输出放置障碍物后的迷宫---------------------------------
   
 do
 {
  printf("\n设置障碍物位置(例如:'2,3';输入'0,0'退出设置):");
  scanf("%d,%d",&p,&q);
  system("cls"); //清屏语句,保持窗口的简洁性
  printf("               ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆\n");
  printf("               ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆\n");
  printf("               ☆☆☆                              ☆☆☆\n");
  printf("               ☆☆☆                              ☆☆☆\n");
  printf("               ☆☆☆          老邓疯狂迷宫        ☆☆☆\n");
  printf("               ☆☆☆                              ☆☆☆\n");
  printf("               ☆☆☆                     COME ON! ☆☆☆\n");
  printf("               ☆☆☆                              ☆☆☆\n");
  printf("               ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆\n");
  printf("               ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆\n");
  printf("\n");
  printf("\n");
  printf("\n");
  maze[p][q] = 1;
  for(x=0; x<=N+1; x++)
  {   printf("\n\t\t\t\t");
   for(y=0; y<=N+1; y++)
   {
    if(maze[x][y]==1) printf("◆");
    else printf(" ");
   }
  }
 }while(p!=0 && q!=0);

//-----------------------------------输出结果-----------------------------------------------
   printf("\n按任意键查看结果……:");
   system("pause");   
   printf("\n从(1,1)到(%d,%d)的最短路径为\n",N,N);
   mazepath(1,1,N,N);
   printf("\n--------OH YEAR!--------\n");
}
 
搜索更多相关主题的帖子: 最大值 include 
2011-12-16 09:23
waterstar
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:5
帖 子:984
专家分:2810
注 册:2010-2-12
收藏
得分:10 
你明明用的是c标准库为什么要把iostream头文件包含进去呢?整个程序没看见你用cout,endl这种标准c++库中的对象,不要以为加了个头文件就是c++了,c++没你想象的那么简单。

把这个移到c版块去,那里很多人都能帮你。

冰冻三尺,非一日之寒;士别三日,不足刮目相看!
2011-12-16 11:33
wj7072005
Rank: 2
等 级:论坛游民
帖 子:7
专家分:47
注 册:2011-12-16
收藏
得分:10 
确实比较混乱
2011-12-16 14:51
蜀山小二V
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2011-12-15
收藏
得分:0 
呃 ……
我确实混乱了~~
2011-12-18 13:28
快速回复:【自己困在自己的迷宫了。。。。】
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.018462 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved