冒泡排序

经典排序算法 - 冒泡排序Bubble sort

原理是临近的数字两两进行比较,按照从小到大或者从大到小的顺序进行交换,

这样一趟过去后,最大或最小的数字被交换到了最后一位,

然后再从头开始进行两两比较交换,直到倒数第二位时结束,其余类似看例子

例子为从小到大排序,

原始待排序数组| 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


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

推荐阅读更多精彩内容

  • 概念 冒泡排序(Bubble Sort):重复地循环要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换...
    AceKitty阅读 197评论 0 0
  • 原理是临近的数字两两进行比较,按照从小到大或者从大到小的顺序进行交换, 这样一趟过去后,最大或最小的数字被交换到了...
    小叮当爱学习阅读 458评论 0 0
  • 原理是临近的数字两两进行比较,按照从小到大或者从大到小的顺序进行交换,这样一趟过去后,最大或最小的数字被交换到了最...
    TimHsieh阅读 913评论 0 0
  • 冒泡排序的基本思想是:每次比较两个相邻的元素,如果它们的顺序错误就把它们交换过来。这样一趟过去后,最大或最小的数字...
    水欣阅读 188评论 0 0
  • 那扇门,是我记忆的开始。 小的时候,家里就有一扇竹子做的门,每天进进出出,都要经过,那年我8岁,门是刚刚做好...
    金勇的小屋阅读 228评论 0 0