小肥羊演算法學習01-----冒泡排序

來源:互聯網
上載者:User

標籤:

  冒泡演算法,顧名思義,就是按一定的順序排列的資料。

演算法思路:

  假設有一個這樣的數組

int[] arr = {5, 9, 3, 1, 2, 6, 7, 4, 8};

  根據演算法定義,我們需要的輸出為

int[] arr = {1, 2, 3, 4, 5, 6, 7, 8, 9};

  首先,拿到我們原數組。先判斷arr[0]和arr[1]的大小。如果arr[0]>arr[1],則交換他們的位置。然後再比較arr[1]和arr[2]的大小,如果arr[1]>arr[2],則交換他們的位置。以此類推,在遍曆一次數組之後,就可以將最大的數放到數組的最後。此時這個步驟被執行了arr.Length-1次,既8次。然後執行第二輪,將第二大的數字通過遍曆比較數組大小移到數組的倒數第二的位置。以此類推就可以將給定的數組按照冒泡排序排列成新的順序。

  關於時間複雜度的計算:

    第一輪執行了m次,第二輪執行了m-1次,一共執行了m輪。

    所以對應的時間複雜度為:O((1+m)/2)*m。忽略較小的常數,則冒泡排序的時間複雜度為O(m^2)

附上C#實現的代碼:

    

        static int[] arr = { 5, 9, 3, 1, 2, 6, 7, 4, 8 };        static void Main(string[] args)        {            for (int i = 0; i < arr.Length - 2; i++)            {                for (int j = 0; j < arr.Length - 1 - i; j++)                {                    if (arr[j] < arr[j + 1])                    {                        Bubbling(j, j + 1);                    }                }            }            foreach (var a in arr)            {                Console.WriteLine(a);            }            Console.Read();        }        static void Bubbling(int one, int two)        {            int buff = arr[one];            arr[one] = arr[two];            arr[two] = buff;        }

小肥羊演算法學習01-----冒泡排序

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.