欢迎来到爱思文秘网!

心迷宫|寻找迷宫的一条出路,o通路;X:障碍

七一党建专题 时间:2018-01-28

【www.98iis.net--七一党建专题】

  #define MAX_SIZE 8

  int H[4] = {0, 1, 0, -1};

  int V[4] = {-1, 0, 1, 0};

  char Maze[MAX_SIZE][MAX_SIZE] = {{‘X’,'X’,'X’,'X’,'X’,'X’,'X’,'X’},

  {‘o’,'o’,'o’,'o’,'o’,'X’,'X’,'X’},

  {‘X’,'o’,'X’,'X’,'o’,'o’,'o’,'X’},

  {‘X’,'o’,'X’,'X’,'o’,'X’,'X’,'o’},

  {‘X’,'o’,'X’,'X’,'X’,'X’,'X’,'X’},

  {‘X’,'o’,'X’,'X’,'o’,'o’,'o’,'X’},

  {‘X’,'o’,'o’,'o’,'o’,'X’,'o’,'o’},

  {‘X’,'X’,'X’,'X’,'X’,'X’,'X’,'X’}};

  void FindPath(int X, int Y) {

  if(X == MAX_SIZE || Y == MAX_SIZE) {

  for(int i = 0; i < MAX_SIZE; i++)

  for(int j = 0; j < MAX_SIZE; j++)

  printf(“%c%c”, Maze[i][j], j < MAX_SIZE-1 ? ‘ ‘ : ‘\n’);

  }else for(int k = 0; k < 4; k++)

  if(X >= 0 && Y >= 0 && Y < MAX_SIZE && X < MAX_SIZE && ‘o’ == Maze[X][Y]) {

  Maze[X][Y] = ‘ ‘;

  FindPath(X+V[k], Y+H[k]);

  Maze[X][Y] =’o';

  }

  }

  int main(int argc, char* argv[]) {

  FindPath(1,0);

  }

本文来源:http://www.98iis.net/jierizhuanti/19560/

推荐内容