golang-数据结构-冒泡排序

冒泡排序算法

  1. 冒泡算法,数组中前一个元素和后一个元素进行比较如果大于/小于 前者就进行交换,最终返回最大/最小都冒到数组的最后序列时间复杂度为 O(n^2).

  2. 从数组开头选择相邻两个元素进行比较,并进行交换

  3. 不停向后移动

  4. package main
    
    import (
    	"fmt"
    	"log"
    )
    
    /**
    冒泡排序获取最大值
    */
    func GetMax(arr []int) int {
    	for j := 1; j < len(arr); j++ {
    		if arr[j-1] > arr[j] {
    			arr[j-1], arr[j] = arr[j], arr[j-1]
    		}
    	}
    	return arr[len(arr)-1]
    }
    
    /**
    冒泡排序
    */
    func BubbleSort(arr []int) []int {
    	for i := 0; i < len(arr); i++ {
    		for j := i + 1; j < len(arr); j++ {
    			if arr[i] > arr[j] {
    				arr[i], arr[j] = arr[j], arr[i]
    			}
    		}
    		log.Printf("i=%d,%v", i, arr)
    	}
    	return arr
    }
    func main() {
    	arr := []int{1, 9, 10, 30, 2, 5, 45, 8, 63, 234, 12}
    	fmt.Println(GetMax(arr))
    	fmt.Println(BubbleSort(arr))
    	/**
    	234
    	2022/10/18 22:16:53 i=0,[1 9 10 2 5 30 8 45 63 12 234]
    	2022/10/18 22:16:53 i=1,[1 2 10 9 5 30 8 45 63 12 234]
    	2022/10/18 22:16:53 i=2,[1 2 5 10 9 30 8 45 63 12 234]
    	2022/10/18 22:16:53 i=3,[1 2 5 8 10 30 9 45 63 12 234]
    	2022/10/18 22:16:53 i=4,[1 2 5 8 9 30 10 45 63 12 234]
    	2022/10/18 22:16:53 i=5,[1 2 5 8 9 10 30 45 63 12 234]
    	2022/10/18 22:16:53 i=6,[1 2 5 8 9 10 12 45 63 30 234]
    	2022/10/18 22:16:53 i=7,[1 2 5 8 9 10 12 30 63 45 234]
    	2022/10/18 22:16:53 i=8,[1 2 5 8 9 10 12 30 45 63 234]
    	2022/10/18 22:16:53 i=9,[1 2 5 8 9 10 12 30 45 63 234]
    	2022/10/18 22:16:53 i=10,[1 2 5 8 9 10 12 30 45 63 234]
    	[1 2 5 8 9 10 12 30 45 63 234]
    
    	*/
    }
    
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小哥(xpc)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值