• 冒泡法排序


        冒泡法排序,顾名思义,整个排序过程实际上一次次的冒泡过程,每次冒泡都会进行相邻数字的比较,如果Left>Right,则交换,一次冒泡完毕后,数组最大的值就会被安置到最后的位置。然后进行第二次冒泡,这次冒泡就会将次大值安置到n-1的记录上。依此类推。

        冒泡法排序的算法复杂度O(n2).

      C++代码如下:

    #include "stdafx.h"
    
    /************************************************************************/
    /*                             冒泡排序                                  */
    /************************************************************************/
    void BubbleSort(int data[], int n)
    {
        for (int i=0; i<n-1; i++)
        {
            bool exchange = false;
            for (int j=0; j<n-i-1; j++)
            {
                if (data[j] > data[j+1])
                {
                    int tmp = data[j];
                    data[j] = data[j+1];
                    data[j+1] = tmp;
                    exchange = true;
                }
            }
            if (!exchange)
                break;
        }
    }
    
    int _tmain(int argc, _TCHAR* argv[])
    {
        int data[10]={-100, 79, -3, 0, 49, 21, 8, 200, 12341, 0};
        BubbleSort(data, 10);
    
        return 0;
    }

      注意两个问题:

      1. 冒泡法排序比较的是相邻的两个元素,而不是头元素和之后的几个元素相比,网上一些写法错误于此,归根结底就是自己没有实际去手写一边冒泡排序,想当然了;

      2. 注意循环结束的条件,并不是一定要一直比较直到程序结束,而是当一次比较过程中没有交换操作的时候,程序即可终止;

           3. 冒泡法排序的算法复杂度是O(n2)。

  • 相关阅读:
    关于int8_t,uint8_t.....等数据类型的理解
    导出函数__declspec(dllexport)
    c++中的namespace
    GitHub C 和 C++ 开源库的清单(含示例代码)
    进制之间的转换一
    为 JSON 字符串创建对象
    HTML5 简单Demo1
    主要浏览器的调试工具
    fiddler2抓包工具使用图文教程
    JAVA将秒的总和转换成时分秒的格式
  • 原文地址:https://www.cnblogs.com/jiayayao/p/6135972.html
Copyright © 2020-2023  润新知