抱歉,您的浏览器无法访问本站
本页面需要浏览器支持(启用)JavaScript
了解详情 >

冒泡排序

思路:从左向右每次两两比较相邻元素,如果前一个元素大于后一个元素,那么就交换这两个元素,一趟下来肯定有一个元素放到了最后的位置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
func BubbleSort(nums []int) []int {
bubbleSort(nums)
return nums
}

func bubbleSort(nums []int) {
//从前往后进行交换,每次都会固定好后面的元素
for i := 0; i < len(nums)-1; i++ {
for j := 0; j < len(nums)-1-i; j++ {
//两两比较并交换
if nums[j] > nums[j+1] {
nums[j], nums[j+1] = nums[j+1], nums[j]
}
}
}
}

直接插入排序

直接插入排序是简单排序中性能最好的

平均时间复杂度:O(n^n / 4)
最好时间复杂度:O(n)
最坏时间复杂度:O(n^n)

直接插入排序版本1

思路:将每次要插入的当前元素依次与左边元素比较,如果左边元素大于当前元素则交换,直到左边元素小于等于当前元素。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
package main

import (
"log"
"math/rand"
"time"
)

/**
* @Author: yirufeng
* @Email: yirufeng@foxmail.com
* @Date: 2020/9/10 9:12 上午
* @Desc: 直接插入排序
*/

func InsertSort(nums []int) []int {
insertSort(nums)
return nums
}

//思路:如果当前元素比前一个元素小就交换,一直到当前元素大于等于前一个元素
func insertSort(nums []int) {
//默认下标为0的已经有序,因此从下标为1的开始插入
for i := 1; i < len(nums); i++ {
//插入条件:要排序的元素一定要小于前面的元素
if nums[i] < nums[i-1] {
//什么时候结束插入:当要插入的元素的值大于等于前面的那个元素就停止插入
for j := i; j >= 1 && nums[j] < nums[j-1]; j-- {
nums[j], nums[j-1] = nums[j-1], nums[j]
}
}
}
}


//写一个随机数生成器
func RandArray(length int) []int {
nums := []int{}
for i := 0; i < length; i++ {
r := rand.New(rand.NewSource(time.Now().UnixNano()))
nums = append(nums, r.Intn(100))
}
return nums
}

func main() {
rand.Seed(time.Now().UnixNano())
nums := RandArray(30)
log.Println(nums)
log.Println(InsertSort(nums))
}

如果不想使用nvm进行node多版本的管理,直接可以使用去node中文网 下载LTS版本(安装的时候记得添加到环境变量选项要勾上),安装后从第四步开始执行

第一步:安装nvm

这一步mac和windows有所区别

  • 执行curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.8/install.sh | bashwget -qO- https://raw.githubusercontent.com/creationix/nvm/v0.33.8/install.sh | bash
  • 安装完成后关闭终端,然后键入nvm看一下是否有输出,如果command not found查看
  • nvm ls查看所有已安装node的版本,并且使用node use <version>命令选择一个合适的node用来安装hexo

补充:nvm常用命令介绍

1
2
3
4
5
6
● nvm install stable  安装最新稳定版 node
● nvm install <version> 安装指定版本,如:安装v4.4.0,nvm install v4.4.0
● nvm uninstall <version> 删除已安装的指定版本,语法与install类似
● nvm use <version> 切换使用指定的版本node
● nvm ls 列出所有安装的版本
● nvm alias default <version> 如: nvm alias default v11.1.0