zoukankan      html  css  js  c++  java
  • 迷宫问题(回溯法)

    --------------------------------写在前面----------------------------------------

    作为初学者的我表示这个程序真心不能自己写出来,花了一些时间才看懂@JackyBing写的这段代码,并改了一些东西

    感谢@JackyBing的代码,书上的真心没看懂,现在理解了,

    呜呜呜,感觉自己好弱呀,这都看了这么久,还是得像大神看齐。

    一起学习,共同进步!

    --------------------------------核心算法----------------------------------------

    do

    {

    if(当前的路径可以通过)

    {

    留下足迹;

    将当前位置保存并入栈

    if(判断当前路径是否为最终路径)

    {

    退栈,并修改迷宫的数据,记录所走的路线

    并返回 1;

    }

    当前步数增一;

    获取下一位置;

    }

    else//当前位置走不通

    {

    if(当前栈不为空)

    {

    退栈;

    while(当前位置的所走方向为4并且当

    当前栈不为空)

    {

    记录当前位置不为走不通;

    退栈处理;

    当前步数减一;

    }

    if(当前的位置所走方向小于4)

    {

    将当前位置的方向增一;

    将当前位置重新进栈;

    获取下一将要通过的位置;

    }

    }

    }

    }

    --摘自http://www.cnblogs.com/JackyTecblog/archive/2011/02/20/1958880.html

      1 #include<iostream>
      2 #include<stdlib.h>
      3 
      4 using namespace std;
      5 
      6 #define STACK_INIT_SIZE 100
      7 #define STACKINCREASE 10
      8 #define MAZESIZE 10
      9 
     10 
     11  typedef struct Postion
     12 {
     13      int x;
     14      int y;
     15 }Postion;
     16 
     17 
     18 typedef struct
     19 {
     20     Postion pos;//通道块在迷宫中的“坐标位置”
     21     int curstep;//通道块在路径中的“序号”
     22     int dir;//从此通道块走向下一通道块的“方向”
     23 }mazenode;
     24 
     25 
     26 typedef struct
     27 {
     28     mazenode *base;
     29     mazenode *top;
     30     int stacksize;
     31 }SqStack,*LinkStack;
     32 
     33 
     34 int InitStack(LinkStack &S)
     35 {
     36     S->base=(mazenode *)malloc(STACK_INIT_SIZE*sizeof(mazenode));
     37     if(!S->base)
     38     {
     39         cout<<"分配空间失败!";
     40         exit(-1);
     41     }
     42     S->top=S->base;
     43     S->stacksize=STACK_INIT_SIZE;
     44     return 0;
     45 }
     46 
     47 
     48 int Push(LinkStack &S,mazenode *e)
     49 {
     50     if((S->top-S->base)>=STACK_INIT_SIZE)
     51     {
     52         S->base=(mazenode *)realloc(S->base,(STACK_INIT_SIZE+STACKINCREASE)*sizeof(mazenode));
     53         if(!S->base)
     54         {
     55            cout<<"分配空间失败!";
     56             exit(-1);
     57         }
     58         S->top=S->base+STACK_INIT_SIZE;
     59         S->stacksize=STACK_INIT_SIZE+STACKINCREASE;
     60     }
     61     *(S->top)=*e;//结构体
     62     S->top++;
     63     return 0;
     64 }
     65 
     66 
     67 int Pop(LinkStack &S,mazenode *e)
     68 {
     69     if(S->base==S->top)
     70     {
     71         cout<<"栈为空!";
     72         exit(0);
     73     }
     74     S->top--;
     75     *e=*(S->top);
     76     return 0;
     77 }
     78 
     79 
     80 int GetTop(LinkStack &S,mazenode *e)
     81 {
     82     if(S->base==S->top)
     83     {
     84         cout<<"栈为空!";
     85         return 0;
     86     }
     87     else
     88     {
     89         *e=*(S->top-1);
     90         return 1;
     91     }
     92 }
     93 
     94 
     95 int EmptyStack(LinkStack &S)
     96 {
     97     if(S->base==S->top) return 1;//stack is empty!
     98     else return 0;//stack is not empty!
     99 }
    100 
    101 
    102 int Pass(Postion pos,int array[MAZESIZE][MAZESIZE])//判断pos位置是否可通
    103 {
    104     if(array[pos.x][pos.y]!=0&&array[pos.x][pos.y]!=-1) return 1;//indicate the way can pass
    105     else return 0;//indicate the way can not pass
    106 }
    107 
    108 
    109 Postion NextPos(Postion pos,int dir)//结构体函数,返回当前位置下一个待判断位置的坐标,顺时针旋转(东->南->西->北)
    110 {
    111     switch(dir)
    112     {
    113         case 1:pos.y+=1;break;
    114         case 2:pos.x+=1;break;
    115         case 3:pos.y-=1;break;
    116         case 4:pos.x-=1;break;
    117         default:break;
    118     }
    119     return pos;
    120 }
    121 
    122 
    123 int MarkFoot(int arr[MAZESIZE][MAZESIZE],Postion pos)//标记已经走过了
    124 {
    125     arr[pos.x][pos.y]=0;//have pass by the way
    126     return 0;
    127 }
    128 
    129 int MarkBlock(int arr[MAZESIZE][MAZESIZE],Postion pos)
    130 {
    131     arr[pos.x][pos.y]=-1;//do not pass by the postion
    132     return 0;
    133 }
    134 
    135 
    136 int MazePath(int arr[MAZESIZE][MAZESIZE],Postion start,Postion ending)
    137 {
    138     LinkStack s;
    139     mazenode *p=(mazenode*)malloc(sizeof(mazenode));
    140     mazenode *nodelist=(mazenode *)malloc(100*sizeof(mazenode));//记录成功路径
    141     int curstep=1,flag=0;//设定入口位置为路径中的第一个位置
    142     Postion curpos=start,temp;//设定当前位置为入口位置
    143     InitStack(s);
    144     do
    145     {
    146         if(Pass(curpos,arr))//当前位置可通
    147         {
    148             MarkFoot(arr,curpos);//很关键,标记在当前位置上的通道不能再往回走了
    149             nodelist[flag].pos=curpos;//将当前位置的内容复制到nodelist数组的相应元素
    150             nodelist[flag].curstep=curstep;
    151             nodelist[flag].dir=1;//towards east
    152             Push(s,nodelist+flag);//将nodelist数组的相应元素压入s栈中
    153             flag++;
    154             if(curpos.x==ending.x&&curpos.y==ending.y)//如果当前位置是终点,则依次将栈中元素的位序赋给它在数组中的相应位置
    155             {
    156                 while(!EmptyStack(s))
    157                 {
    158                     Pop(s,p);//p为当前路径上最后一个位置
    159                     arr[p->pos.x][p->pos.y]=p->curstep;
    160                 }
    161                 return 1;//结束
    162             }
    163             curstep++;
    164             curpos=NextPos(curpos,1);//towards east
    165         }
    166         else//当前位置不可通
    167         {
    168             if(!EmptyStack(s))
    169             {
    170                 Pop(s,p);
    171                 while(p->dir==4&&!EmptyStack(s))
    172                 {
    173                     MarkBlock(arr,p->pos);//mark that the way is not passed
    174                     Pop(s,p);
    175                     curstep--;
    176                 }
    177                 if(p->dir<4)
    178                 {
    179                     p->dir++;
    180                     Push(s,p);
    181                     temp=p->pos;
    182                     curpos=NextPos(temp,p->dir);
    183                 }
    184             }
    185         }
    186     }while(!EmptyStack(s));
    187     return 0;//failure
    188 }
    189 
    190 
    191 
    192 int main()
    193 {
    194     int maze[MAZESIZE][MAZESIZE]={
    195         {0,0,0,0,0,0,0,0,0,0},
    196         {0,1,1,0,1,1,1,0,1,0},
    197         {0,1,1,0,1,1,1,0,1,0},
    198         {0,1,1,1,1,0,0,1,1,0},
    199         {0,1,0,0,0,1,1,1,1,0},
    200         {0,1,1,1,0,1,1,1,1,0},
    201         {0,1,0,1,1,1,0,1,1,0},
    202         {0,1,0,0,0,1,0,0,1,0},
    203         {0,0,1,1,1,1,1,1,1,0},
    204         {0,0,0,0,0,0,0,0,0,0}},i,j,flag;
    205     Postion start,ending;
    206     start.x=1;start.y=1;
    207     ending.x=8;ending.y=8;
    208     cout<<"primative maze:"<<endl;
    209     for(i=0;i<MAZESIZE;i++)
    210     {
    211         for(j=0;j<MAZESIZE;j++) cout<<maze[i][j]<<"	";
    212         cout<<endl<<endl;
    213     }
    214     flag=MazePath(maze,start,ending);
    215     if(flag==1)
    216     {
    217         cout<<"maze processing success!"<<endl;
    218         cout<<"processed maze:"<<endl;
    219         for(i=0;i<MAZESIZE;i++)
    220         {
    221             for(j=0;j<MAZESIZE;j++) cout<<maze[i][j]<<"	";
    222             cout<<endl<<endl;
    223         }
    224     }
    225     else cout<<"maze processing fail"<<endl;
    226     return 0;
    227 }
    只有0和1的世界是简单的
  • 相关阅读:
    apue学习笔记(第十二章 线程控制)
    apue学习笔记(第十一章 线程)
    apue学习笔记(第十章 信号)
    apue学习笔记(第九章 进程关系)
    apue学习笔记(第八章 进程控制)
    apue学习笔记(第七章 进程环境)
    apue学习笔记(第六章 系统数据文件和信息)
    apue学习笔记(第五章 标准I/O)
    apue学习笔记(第四章 文件和目录)
    apue学习笔记(第三章 文件I/O)
  • 原文地址:https://www.cnblogs.com/nullxjx/p/5906223.html
Copyright © 2011-2022 走看看