(Swift 实现)排序 —— 归并排序

前端之家收集整理的这篇文章主要介绍了(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))

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

猜你在找的Swift相关文章