qsort-ints-nopa.vs
684 Bytes
# quicksort recursivo, com a instrução "break".
MAX: int = 100000;
array: [MAX] int;
qsort = map (l, r) -> () [
i := l;
j := r;
x := array[(l+r)/2];
* [ true -> * [ array[i] < x -> i := i+1; ];
* [ x < array[j] -> j := j-1; ];
? [ i <= j -> (array[i], array[j]) := (array[j], array[i]);
i := i+1;
j := j-1; ];
? [ i > j -> break; ] ];
? [ l<j -> @ (l, j) ];
? [ i<r -> @ (i, r) ];
];
initialize = map () -> () [
i := 0;
r := 333;
* [ i<MAX -> r := (1317 * r) % 214748;
array[i] := r;
i := i+1; ]
];
program = map () -> () [
initialize ();
qsort (0, MAX-1);
]