311-golang排序算法

本文深入讲解了八种经典的排序算法,包括冒泡排序、选择排序、插入排序、快速排序、希尔排序、堆排序、归并排序和计数排序。通过具体的代码实现,详细解析了每种算法的工作原理和步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >






主要的排序算法有:
1.冒泡
2.选择
3.插入
4.快速排序
5.希尔排序
6.堆排序
7.归并排序
8.计数排序等等




1.
先来看下冒泡排序

	arr := []int{3, 5, 4, 1, 2}

	for i := 0; i < len(arr)-1; i++ {
		for j := 0; j < len(arr)-1-i; j++ {
			if arr[j] > arr[j+1] {
				arr[j], arr[j+1] = arr[j+1], arr[j]
			}
		}
	}

	fmt.Println(arr)







2.
然后看下选择排序

	arr := []int{3, 5, 4, 1, 2}

	for i := 0; i < len(arr); i++ {

		temp := i

		for j := i; j < len(arr); j++ {
			if arr[temp] > arr[j] {
				temp = j
			}
		}

		arr[i], arr[temp] = arr[temp], arr[i]
	}

	fmt.Println(arr)










3.
然后看下插入法

	arr := []int{3, 5, 4, 1, 2}

	for i := 1; i < len(arr); i++ {
		for j := i; j >= 1; j-- {
			if arr[j-1] > arr[j] {
				arr[j-1], arr[j] = arr[j], arr[j-1]
			}
		}

	}

	fmt.Println(arr)









4.
快速排序

// 第一种写法
func quickSort(values []int, left, right int) {
    temp := values[left]
    p := left
    i, j := left, right
 
    for i <= j {
        for j >= p && values[j] >= temp {
            j--
        }
        if j >= p {
            values[p] = values[j]
            p = j
        }
 
        for values[i] <= temp && i <= p {
            i++
        }
        if i <= p {
            values[p] = values[i]
            p = i
        }
    }
    values[p] = temp
    if p-left > 1 {
        quickSort(values, left, p-1)
    }
    if right-p > 1 {
        quickSort(values, p+1, right)
    }
}
 
func QuickSort(values []int) {
    if len(values) <= 1 {
        return
    }
    quickSort(values, 0, len(values)-1)
}
 
// 第二种写法
func Quick2Sort(values []int) {
    if len(values) <= 1 {
        return
    }
    mid, i := values[0], 1
    head, tail := 0, len(values)-1
    for head < tail {
        fmt.Println(values)
        if values[i] > mid {
            values[i], values[tail] = values[tail], values[i]
            tail--
        } else {
            values[i], values[head] = values[head], values[i]
            head++
            i++
        }
    }
    values[head] = mid
    Quick2Sort(values[:head])
    Quick2Sort(values[head+1:])
}
 
// 第三种写法
func Quick3Sort(a []int,left int, right int)  {
 
    if left >= right {
        return
    }
 
    explodeIndex := left
 
    for i := left + 1; i <= right ; i++ {
 
        if a[left] >= a[i]{
 
            //分割位定位++
            explodeIndex ++;
            a[i],a[explodeIndex] = a[explodeIndex],a[i]
 
 
        }
 
    }
 
    //起始位和分割位
    a[left], a[explodeIndex] = a[explodeIndex],a[left]
 
    Quick3Sort(a,left,explodeIndex - 1)
    Quick3Sort(a,explodeIndex + 1,right)
 
}








5.
希尔排序

	arr := []int{3, 5, 4, 1, 2}

	//希尔排序
	d := len(arr)
	for ; ; {
		d = d / 2
		for x := 0; x < d; x++ {
			for i := x + d; i < len(arr); i = i + d {
				temp := arr[i]
				j := 0
				for j = i - d; j >= 0 && arr[j] > temp; j = j - d {
					arr[j+d] = arr[j]
				}
				arr[j+d] = temp
			}
		}
		if d == 1 {
			break;
		}
	}

	fmt.Println(arr)







 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值