Browse Source

refactoring: character durch WEG ersetzt

remotes/origin/Labyrinth
Ronja Awe 2 years ago
parent
commit
a02f1e1692
  1. 13
      src/c/labyrinth.c
  2. 1
      src/c/labyrinth.h

13
src/c/labyrinth.c

@ -20,29 +20,30 @@ int printlabyrinth(lab laby, int hoehe, int breite){
return 0; return 0;
} }
void wegsuchen(lab laby, bool* done, int y, int x, int ziely, int zielx){ void wegsuchen(lab laby, bool* done, int y, int x, int ziely, int zielx){
laby[y][x] = 'X'; laby[y][x] = 'X';
if(x == zielx && y == ziely){ if(x == zielx && y == ziely){
*done = true; *done = true;
} }
else{ else{
if (!*done && y + 1 <= ziely && laby[y+1][x] == '0'){
if (!*done && y + 1 <= ziely && laby[y+1][x] == WEG){
wegsuchen(laby, done, y + 1, x, ziely, zielx); wegsuchen(laby, done, y + 1, x, ziely, zielx);
} }
if (!*done && x + 1 <= zielx && laby[y][x+1] == '0'){
if (!*done && x + 1 <= zielx && laby[y][x+1] == WEG){
wegsuchen(laby, done, y, x + 1, ziely, zielx); wegsuchen(laby, done, y, x + 1, ziely, zielx);
} }
if (!*done && y - 1 >= 0 && laby[y-1][x] == '0'){ // oben
if (!*done && y - 1 >= 0 && laby[y-1][x] == WEG){ // oben
wegsuchen(laby, done, y - 1, x, ziely, zielx); wegsuchen(laby, done, y - 1, x, ziely, zielx);
} }
if (!*done && x - 1 >= 0 && laby[y][x-1] == '0'){ // links
if (!*done && x - 1 >= 0 && laby[y][x-1] == WEG){ // links
wegsuchen(laby, done, y, x - 1, ziely, zielx); wegsuchen(laby, done, y, x - 1, ziely, zielx);
} }
if (!*done){ if (!*done){
laby[y][x] = '0';
laby[y][x] = WEG;
} }
} }
} }

1
src/c/labyrinth.h

@ -5,6 +5,7 @@
#define MAXZEILEN 10 #define MAXZEILEN 10
#define MAXSPALTEN 10 #define MAXSPALTEN 10
#define WEG '0'
typedef char lab[MAXZEILEN][MAXSPALTEN]; typedef char lab[MAXZEILEN][MAXSPALTEN];
int printlabyrinth(lab laby, int hoehe, int breite); int printlabyrinth(lab laby, int hoehe, int breite);

Loading…
Cancel
Save