Swift实现四种简单的排序算法

一、冒泡排序

// 冒泡排序
for i in 0..<list.count {
    for j in i+1..<list.count {
        if list[i] > list[j] {
            let temp = list[i]
            list[i] = list[j]
            list[j] = temp
        }
    }
}

二、选择排序

// 选择排序
for i in 0..<list.count {
    var min = i
    for j in i+1..<list.count {
        if list[j] < list[min] {
            min = j
        }
    }
    let minValue = list[min]
    list[min] = list[i]
    list[i] = minValue
}

三、插入排序

// 插入排序
for i in 1..<list.count {
    let temp = list[i]
    for j in (1...i).reversed() {
        if list[j - 1] > temp {
            let current = list[j]
            list[j] = list[j-1]
            list[j - 1] = current
        } else {
            break
        }
    }
}

四、希尔排序

// 希尔排序
var gap = list.count / 2

while gap > 0 {
    var j: Int = 0
    for i in 0..<gap {
        j = i + gap
        while j < list.count {
            if list[j] < list[j - gap] {
                let temp = list[j]
                var k = j - gap
                while k >= 0 {
                    if list[k] > temp {
                        list[k + gap] = list[k]
                        list[k] = temp
                    } else {
                        break
                    }
                    k -= gap
                }
            }
            j += gap  
        } 
    }
    gap /= 2
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。