加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-14 06:21:41 所属栏目:百科 来源:网络整理
导读:我的理解,就是把大问题拆成小问题,然后再合并起来就酱 直接上代码,在Swift执行一遍就看见了,终于想出来了,在playground里面执行,又快又方便呢。 import UIKit var str = "Hello,playground" var a = [ 22 , 13 , 5 , 1 , 23 , 4 , 12 , 54 , 56 , 34 ,

我的理解,就是把大问题拆成小问题,然后再合并起来就酱
直接上代码,在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))

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读