迷宫小程序

来源:互联网 发布:wish产品优化技巧 编辑:程序博客网 时间:2024/05/16 00:39

#include "stdafx.h"
#include "iostream"
#include "malloc.h"
using namespace std;
#define row 7
#define column 6
struct node
{
 int x;
 int y;
 int d;
};
typedef struct node_1
{
 node move[20];
 int top;
}Stack;

void init_stack(Stack &stack)
{
 stack.top=-1;
}

void push_stack(Stack &stack,int a,int b,int c)
{
 stack.top++;
 stack.move[stack.top].x=a;
 stack.move[stack.top].y=b;
 stack.move[stack.top].d=c;

}

void pop_stack(Stack &stack)
{
 stack.top--;
}
int search_d(int p[][column],int m,int n,int d)
{
 switch(d)
 {
 case 0:return p[m][n+1];
  break;
 case 1:return p[m+1][n+1];
  break;
 case 2:return p[m+1][n];
  break;
 case 3:return p[m+1][n-1];
  break;
 case 4:return p[m][n-1];
  break;
 case 5:return p[m-1][n-1];
  break;
 case 6:return p[m-1][n];
  break;
 case 7:return p[m-1][n+1];
  break;
 }
}


void print_map(Stack &stack) //打印出当时的路径
{
 int i;
 for(i=0;i<=stack.top;i++)
 {
  printf("(%d,%d) ",stack.move[i].x,stack.move[i].y);
 }

 printf("(%d,%d)\n",row-2,column-2);
}

void move_map(Stack &stack,int p[][column])//小球走的过程
{
 int m=1,n=1,d=0;
 while(1)
 {
  while(d<8)
  {
   if(search_d(p,m,n,d)==0)
   {
    push_stack(stack,m,n,d);
    p[m][n]=-1;
    switch(d)
    {
    case 0:{n++;}
        break;
    case 1:{m++;n++;}
        break;
    case 2:{m++;}
        break;
    case 3:{m++;n--;}
        break;
    case 4:{n--;}
        break;
    case 5:{m--;n--;}
        break;
    case 6:{m--;}
        break;
    case 7:{m--;n++;}
        break;
    default:printf("The error:\n");
     break;
    }
    d=0;
   }
   else d++;
   if(m==row-2&&n==column-2) break;

  }
  if( 8 ==  d)
  {
   d=stack.move[stack.top].d+1;
         m=stack.move[stack.top].x;
      n=stack.move[stack.top].y;
   pop_stack(stack);
  }

  if(m==row-2&&n==column-2)
  {
   print_map(stack);
   d=stack.move[stack.top].d+1;
   m=stack.move[stack.top].x;
   n=stack.move[stack.top].y;
   pop_stack(stack);
   p[m][n]=0;
  }


  if(m==1&&n==1) break;
 }

}

 //void  ssss()
 //{
 // while (1)
 // {
 //  while (1)
 //  {
 //  int a = 0;
 //   if(1)
 //   {
 //   a++;
 //    if (a>0)
 //    {
 //     
 //     for(int i = 0; i<= 10; i++ )
 //      {
 //       
 //       break;    //结束最近的循环,不判断,switch也算是循环
 //       continue; //结束最近的循环,判断
 //      }
 //      
 //     
 //     break;
 //    }
 //    break;
 //   }
 //  }
 // }
 //}

int _tmain(int argc, _TCHAR* argv[])
{
 /*ssss();*/
 Stack stack;
 int p[row][column]={{1,1,1,1,1,1},{1,0,0,1,1,1},{1,1,0,0,1,1},{1,1,1,0,0,1},{1,1,1,1,0,1},{1,1,1,1,0,1},{1,1,1,1,1,1}};
 init_stack(stack);
 move_map(stack,p);
 system("pause");
}

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 一岁宝宝太调皮怎么办 怀孕早期喝了酒怎么办 怀孕期间喝了酒怎么办 一岁宝宝多动怎么办 3岁前儿童多动症怎么办 好动症的孩子该怎么办 18个月宝宝腹泻怎么办 8个月小孩发烧怎么办 八个月大宝宝发烧怎么办 8个月宝宝拉稀水怎么办 八个月宝宝38度怎么办 8个月的宝宝发烧怎么办 八个月大的宝宝拉肚子怎么办 9孩子上课坐不住怎么办 3岁宝宝太皮怎么办 4岁的宝宝多动症怎么办 小孩好动注意力不集中怎么办 乐扣加热变形了怎么办 3岁宝宝咳嗽厉害怎么办 六个月婴儿呕奶怎么办 刚出生婴儿呕奶怎么办 宝宝拉颗粒便便怎么办 奶水不够宝宝又不吃奶粉怎么办 一岁突然不吃饭怎么办 母乳不够吃宝宝不吃奶粉怎么办 八个月不吃辅食怎么办 孩子长得太快怎么办 反复发烧到39度怎么办 儿童发烧到39度怎么办 7岁儿童发烧40度怎么办 7岁反复发烧39度怎么办 宝宝烧到39.5度怎么办 3岁儿童发烧39度怎么办 孩子发高烧怎么办39度5 3岁宝宝不吃水果怎么办 2岁宝宝不吃水果怎么办 4岁宝宝不吃水果怎么办 过早竖抱婴儿了怎么办 3个月宝宝认生怎么办 10天婴儿不拉屎怎么办 3个月宝宝不吃奶粉怎么办