iOS算法之冒泡排序

作者: 一个人在路上走下去 | 来源:发表于2016-07-30 14:47 被阅读1158次

    冒泡排序是一种简单的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。

    算法分析

    比较相邻的元素。如果第一个比第二个大,就交换他们两个。对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。针对所有的元素重复以上的步骤,除了最后一个。持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

    原始待排序数组| 6 | 2 | 4 | 1 | 5 | 9 |

    第一趟排序(外循环)
    第一次两两比较6 > 2交换(内循环)
    交换前状态| 6 | 2 | 4 | 1 | 5 | 9 |
    交换后状态| 2 | 6 | 4 | 1 | 5 | 9 |

    第二次两两比较,6 > 4交换
    交换前状态| 2 | 6 | 4 | 1 | 5 | 9 |
    交换后状态| 2 | 4 | 6 | 1 | 5 | 9 |

    第三次两两比较,6 > 1交换
    交换前状态| 2 | 4 | 6 | 1 | 5 | 9 |
    交换后状态| 2 | 4 | 1 | 6 | 5 | 9 |

    第四次两两比较,6 > 5交换
    交换前状态| 2 | 4 | 1 | 6 | 5 | 9 |
    交换后状态| 2 | 4 | 1 | 5 | 6 | 9 |

    第五次两两比较,6 < 9不交换
    交换前状态| 2 | 4 | 1 | 5 | 6 | 9 |
    交换后状态| 2 | 4 | 1 | 5 | 6 | 9 |

    第二趟排序(外循环)
    第一次两两比较2 < 4不交换
    交换前状态| 2 | 4 | 1 | 5 | 6 | 9 |
    交换后状态| 2 | 4 | 1 | 5 | 6 | 9 |

    第二次两两比较,4 > 1交换
    交换前状态| 2 | 4 | 1 | 5 | 6 | 9 |
    交换后状态| 2 | 1 | 4 | 5 | 6 | 9 |

    第三次两两比较,4 < 5不交换
    交换前状态| 2 | 1 | 4 | 5 | 6 | 9 |
    交换后状态| 2 | 1 | 4 | 5 | 6 | 9 |

    第四次两两比较,5 < 6不交换
    交换前状态| 2 | 1 | 4 | 5 | 6 | 9 |
    交换后状态| 2 | 1 | 4 | 5 | 6 | 9 |

    第三趟排序(外循环)
    第一次两两比较2 > 1交换
    交换后状态| 2 | 1 | 4 | 5 | 6 | 9 |
    交换后状态| 1 | 2 | 4 | 5 | 6 | 9 |

    第二次两两比较,2 < 4不交换
    交换后状态| 1 | 2 | 4 | 5 | 6 | 9 |
    交换后状态| 1 | 2 | 4 | 5 | 6 | 9 |

    第三次两两比较,4 < 5不交换
    交换后状态| 1 | 2 | 4 | 5 | 6 | 9 |
    交换后状态| 1 | 2 | 4 | 5 | 6 | 9 |

    第四趟排序(外循环)无交换
    第五趟排序(外循环)无交换

    排序完毕,输出最终结果1 2 4 5 6 9

    详细代码请参考Algorithm。参考代码比文字好理解。

    相关文章

      网友评论

        本文标题:iOS算法之冒泡排序

        本文链接:https://www.haomeiwen.com/subject/woqtsttx.html