qsort-ints-temp.vs 722 Bytes
# 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<j -> @ (l, j); ]
    ? [ i<r -> @ (i, r); ] ]

initialize = map () -> () [
    (i, r, j) := (0, 333, 0.5);
    * [ i<MAX -> r := (1317 * r) % 214748;
		 array[i] := (r, j*3.0);
		 j := j+0.5;
		 i := i+1; ] ]

program = map () -> () [
    initialize ();
    qsort (0, MAX-1); ]