import time
import rand

const (
	LEN = 1000 // how many random numbers to generate
	MAX = 10000 // max of the generated numbers
)

fn main() {
	rand.seed(time.now().unix)
	rand.next(MAX) // skip the first
	mut arr := []int
	for _ in 0..LEN {
		arr << rand.next(MAX)
	}
	println('length of random array is $arr.len')
	println('before quick sort whether array is sorted: ${is_sorted(arr)}')
	quick_sort(mut arr, 0, arr.len-1)
	println('after quick sort whether array is sorted: ${is_sorted(arr)}')
}

fn quick_sort(arr mut []int, l int, r int) {
	if l>=r { return }
	mut sep := l  // what is sep: [...all_value<arr[sep]...sep...all_value>=arr[sep]...]
	for i in l+1..r+1 {
		if arr[i] < arr[l] {
			sep++
			swap(mut arr, i, sep)
		}
	}
	swap(mut arr, l, sep)
	quick_sort(mut arr, l, sep-1)
	quick_sort(mut arr, sep+1, r)
}

[inline] 
fn swap(arr mut []int, i int, j int) {
	temp := arr[i]
	arr[i] = arr[j]
	arr[j] = temp
}

fn is_sorted(arr []int) bool {
	for i in 0..arr.len-1 {
		if arr[i] > arr[i+1] {
			return false
		}
	}
	return true
}