File: mazeclean.c

package info (click to toggle)
vim 2%3A8.2.2434-3%2Bdeb11u1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 64,848 kB
  • sloc: ansic: 371,240; cpp: 8,230; makefile: 4,132; perl: 1,405; sh: 1,023; awk: 715; python: 600; xml: 526; lisp: 501; cs: 458; csh: 6; sed: 5
file content (22 lines) | stat: -rw-r--r-- 594 bytes parent folder | download | duplicates (10)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
/*
 * Cleaned-up version of the maze program.
 * Doesn't look as nice, but should work with all C compilers.
 * Sascha Wilde, October 2003
 */
#include <stdio.h>
#include <stdlib.h>

char *M, A, Z, E = 40, line[80], T[3];
int
main (C)
{
  for (M = line + E, *line = A = scanf ("%d", &C); --E; line[E] = M[E] = E)
    printf ("._");
  for (; (A -= Z = !Z) || (printf ("\n|"), A = 39, C--); Z || printf (T))
    T[Z] = Z[A - (E = A[line - Z]) && !C
	     & A == M[A]
	     | RAND_MAX/3 < rand ()
	     || !C & !Z ? line[M[E] = M[A]] = E, line[M[A] = A - Z] =
	     A, "_." : " |"];
  return 0;
}