2
0
mirror of https://github.com/0xAX/go-algorithms synced 2024-11-16 00:12:53 +00:00
go-algorithms/sorting/counting_sort.go
2014-06-27 20:28:17 +06:00

53 lines
887 B
Go

package main
/*
* Counting sort - https://en.wikipedia.org/wiki/Counting_sort
*/
import "fmt"
import "github.com/0xAX/go-algorithms"
func getK(arr []int) int {
if len(arr) == 0 {
return 1
}
k := arr[0]
for _, v := range arr {
if v > k {
k = v
}
}
return k+1
}
func main(){
arr := utils.RandArray(10)
fmt.Println("Initial array is:", arr)
fmt.Println("")
k := getK(arr)
array_of_counts := make([]int, k)
for i:= 0; i < len(arr); i++ {
array_of_counts[arr[i]] += 1
}
for i, j := 0, 0; i < k; i++ {
for {
if array_of_counts[i] > 0 {
arr[j] = i
j += 1
array_of_counts[i] -= 1
continue
}
break
}
}
fmt.Println("Sorted array is: ", arr)
}