zoukankan      html  css  js  c++  java
  • 算法----(1)冒泡排序

    通常所说的排序算法往往指的是内部排序算法,即数据记录在内存中进行排序。

    排序算法大体可分为两种:

    一种是比较排序,时间复杂度O(nlogn)~O(n^2),主要有:冒泡排序,选择排序,插入排序,归并排序,堆排序,快速排序

    另一种是非比较排序,时间复杂度可以达到O(n),主要有:基数排序,基数排序,桶排序

     

    排序算法的稳定性:如果Ai = Aj, 排序前AiAj之前,排序后Ai还在Aj之前,则称这种排序算法是稳定的

    排序算法是否稳定,必须对算法发进行分析从而得到稳定的特性,是否稳定不是绝对的,由具体算法决定

    排序算法稳定性好处,前一个键排序的结果可以为后一个键排序所用

     

    冒泡排序

    重复地走访过要排序的元素,依次比较相邻两个元素,如果他们的顺序错误就把他们调换过来,直到没有元素再需要交换,排序完成。这个算法的名字由来是因为越小(或越大)的元素会经由交换慢慢“浮”到数列的顶端。

    python代码:

     1 def bubble_sort(arr):
     2     for i in range(0, len(arr)):
     3         for j in range(0, len(arr) - i - 1):
     4             if arr[j] > arr[j + 1]:
     5                 arr[j], arr[j + 1] = arr[j+1], arr[j]
     6     for i in range(len(arr)):
     7         print(arr[i])
     8 
     9 
    10 def main():
    11     a = [1, 3, 2, 4, 9, -1]
    12     bubble_sort(a)
    13 
    14 
    15 if __name__ == '__main__':
    16     main()

     图片来源:http://www.cnblogs.com/eniac12/p/5329396.html

  • 相关阅读:
    Thread.join
    Thread.yield
    线程的生命周期
    HashMap底层原理
    Web Services
    Struts2框架
    hibernate乐观锁实现原理
    Hibernate框架
    oracle exp 无法导出空表
    linux 远程复制文件或文件夹
  • 原文地址:https://www.cnblogs.com/MC-Curry/p/9347815.html
Copyright © 2011-2022 走看看