Swift 实现排序 —— 归并排序

我的理解,就是把大问题拆成小问题,然后再合并起来就酱
直接上代码,在Swift执行一遍就看见了,终于想出来了,在playground里面执行,又快又方便呢。

import UIKit

var str = "Hello,playground"

var a = [22,13,5,1,23,4,12,54,56,34,523,2134,21]
//这个我想的先把数组分开,分成一个一个的。
func paixu(_ leftIndex:Int,_ rightIndex:Int) -> (Array<Int>) {
    if leftIndex < rightIndex
    {
    //这个最少也有两个,那就接着往下分
        let i = (rightIndex+leftIndex)/2
    //这里就碰见递归了,paixu这个方法会一直下去,知道剩了一个,那最极端的就是aa里面只有一个元素,bb也是
        var aa = Array(paixu(leftIndex,i))
        var bb = Array(paixu(i+1,rightIndex))

        aa.append(Int.max)
        bb.append(Int.max)
     //返回已排好的序的数组,返回到上一层的paixu这,紧接着又一轮,直到最初的那个paixu。
        return paixushuzu(aa,bb)

    }else
    {
        return [a[rightIndex]]
        //这个显然就是一个返回单个值
    }
}
//这个方法是给定的两个排好序的数组,我会给合在一起,并且按着从小到大的排列
func paixushuzu(_ Arra:Array<Int>,_ Arrb:Array<Int>) -> (Array<Int>) {
    //给定新数组c
    var c = [Int]()

    var aa = 0 //计数Arra的下标
    var bb = 0 //计数Arrb的下标

    //这个条件很巧妙,只有c的个数等于了他们两个数组个数的和才会停止
    while c.count < Arrb.count+Arra.count-2 {
    //谁大取谁,接着下一个
        if Arra[aa] < Arrb[bb]
        {
            c.append(Arra[aa])
            if aa < Arra.count
            {
                aa+=1
            }
        }
        else
        {
            c.append(Arrb[bb])
            if bb < Arrb.count
            {
                bb+=1
            }
        }
    }
    //返回排好序的数组
    return c
}

print(paixu(0,a.count-1))

其实就是递归,分治合,三步就好了。
可视化安利

相关文章

软件简介:蓝湖辅助工具,减少移动端开发中控件属性的复制和粘...
现实生活中,我们听到的声音都是时间连续的,我们称为这种信...
前言最近在B站上看到一个漂亮的仙女姐姐跳舞视频,循环看了亿...
【Android App】实战项目之仿抖音的短视频分享App(附源码和...
前言这一篇博客应该是我花时间最多的一次了,从2022年1月底至...
因为我既对接过session、cookie,也对接过JWT,今年因为工作...