Go 18.0 专业五


03. 冒泡排序算法

<h1>1. 冒泡排序算法</h1> <p>算法描述:冒泡算法,数组中前一个元素和后一个元素进行比较如果大于或者小于 前者就进行交换,最终返回最大或者最小都冒到数组的最后序列时间复杂度为 <strong>O(n^2)</strong>.</p> <h4>算法步骤</h4> <ul> <li>从数组开头选择相邻两个元素进行比较,并进行交换</li> <li> <p>不停向后移动</p> <p>package sort</p> <p>import &quot;fmt&quot;</p> <p>//冒泡排序 func main() { arr := []int{1, 9, 10, 30, 2, 5, 45, 8, 63, 234, 12} fmt.Println(GetMax(arr)) fmt.Println(BubbleSort(arr)) }</p> <p>//冒泡排序获取最大值 func GetMax(arr []int) int { for j := 1; j &lt; len(arr); j++ { if arr[j-1] &gt; arr[j] { arr[j-1], arr[j] = arr[j], arr[j-1] } } return arr[len(arr)-1] }</p> <p>//冒泡排序 func BubbleSort(arr []int) []int { for i := 0; i &lt; len(arr); i++ { for j := i + 1; j &lt; len(arr); j++ { if arr[i] &gt; arr[j] { arr[i], arr[j] = arr[j], arr[i] } } } return arr }</p> </li> </ul>

页面列表

ITEM_HTML