swift 冒泡排序

冒泡排序原理

  • 1.对需要排序的数据,俩俩进行比较,小的放前面,大的放后面

  • 2.依次对每一对相邻的数据作步骤1的工作,当排序到最后一个元素的时候,我们能保证这个数据是最大。

  • 3.针对所有的元素重复以上的步骤,除了最后一个(这里为什么需要针对除了最后一个元素的全部元素做一次呢,因为最后一个元素已经是最大的不需要排序了,同时,由于元素的交换,交换上来的元素的大小不一定比前面的元素的大,所以需要再做一次)。

  • 4持续对越来越少的元素重复3的步骤,直到没有任何一对元素需要比较。

时间复杂度

  • 我们一般谈最坏时间复制度

n(n-1)/2 = O(n²)

算法稳定性

  • 相同元素的前后顺序并没有改变,所以是一种稳定排序算法

swfit代码

import UIKit
import Foundation

var array  = [Int](count:20,repeatedValue: 0)

for index in 0..<20 {
    array[index] = Int(arc4random_uniform(20)) + 1
}
print("排序前的值")
print(array)
for item in array
{
    var ii = item
    print(ii)
}

for i in 0 ..< array.count {
    for j in 0 ..< array.count - 1 - i {
        if array[j] > array[j+1] {
            var  temp = array[j+1]
            array[j+1] = array[j]
            array[j] = temp
        }
    }
}
print("排序后的值")
print(array)
for item in array
{
    var ii = item
    print(ii)
}

值变化图

在playground中我们可以看见值变化情况

排序前.png

第一次两两比较完.png

此时最大的数已经到了最后,后面就不需要比较了

第二次两两比较完..png

此时第二大的数已经到了倒数第二位,后面就不需要比较了

排序完成.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 排序的基本概念 在计算机程序开发过程中,经常需要一组数据元素(或记录)按某个关键字进行排序,排序完成的序列可用于快...
    Jack921阅读 1,460评论 1 4
  • 概述排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部的...
    Luc_阅读 2,300评论 0 35
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 5,220评论 0 52
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 将一个记录插入到已排序好...
    依依玖玥阅读 1,282评论 0 2
  • 因为返校,室友带来了他以前的室友到宿舍暂住,瞎聊了几句。发现现在的年轻人撩妹技能高的可怕,之前的分了没多久,几个月...
    正儿八经的火华兄阅读 170评论 0 1