# recursive quicksort, use break, avoid // assignment. MAX: int = 100000; array: [MAX] { key: int; data: real }; qsort = map (l, r) -> () [ i := l; j := r; x := array[(l+r)/2]; * [ true -> * [ array[i].key < x.key -> i := i+1 ]; * [ x.key < array[j].key -> j := j-1 ]; ? [ i <= j -> t := array[i]; array[i] := array[j]; array[j] := t; i := i+1; j := j-1 ]; ? [ i > j -> break 1 ] ]; ? [ l @ (l, j) ]; ? [ i @ (i, r) ] ]; initialize = map () -> () [ (i, r, j) := (0, 333, 0.5); * [ i r := (1317 * r) % 214748; array[i] := (r, j*3.0); j := j+0.5; i := i+1 ] ]; program = map () -> () [ initialize (); qsort (0, MAX-1); ]