mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
vfmt: vfmt examples/*.v
This commit is contained in:
@ -7,32 +7,34 @@ const (
|
||||
|
||||
fn main() {
|
||||
mut arr := []int{}
|
||||
for _ in 0..gen_len {
|
||||
for _ in 0 .. gen_len {
|
||||
arr << rand.intn(gen_max)
|
||||
}
|
||||
println('length of random array is $arr.len')
|
||||
println('before quick sort whether array is sorted: ${is_sorted<int>(arr)}')
|
||||
quick_sort<int>(mut arr, 0, arr.len-1)
|
||||
quick_sort<int>(mut arr, 0, arr.len - 1)
|
||||
println('after quick sort whether array is sorted: ${is_sorted<int>(arr)}')
|
||||
}
|
||||
|
||||
fn quick_sort<T>(mut arr []T, 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 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++
|
||||
arr[i], arr[sep] = arr[sep], arr[i]
|
||||
}
|
||||
}
|
||||
arr[l], arr[sep] = arr[sep], arr[l]
|
||||
quick_sort<T>(mut arr, l, sep-1)
|
||||
quick_sort<T>(mut arr, sep+1, r)
|
||||
quick_sort<T>(mut arr, l, sep - 1)
|
||||
quick_sort<T>(mut arr, sep + 1, r)
|
||||
}
|
||||
|
||||
fn is_sorted<T>(arr []T) bool {
|
||||
for i in 0..arr.len-1 {
|
||||
if arr[i] > arr[i+1] {
|
||||
for i in 0 .. arr.len - 1 {
|
||||
if arr[i] > arr[i + 1] {
|
||||
return false
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user