快速排序的C++实现(利用二分分治法)
生活随笔
收集整理的這篇文章主要介紹了
快速排序的C++实现(利用二分分治法)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
一、學習要點:
1.先從數列中選取一個數作為基準數。
2.利用區分過程,為這個數確定在排序后數組的位置,區分過程為,比這個數大的數全放到他的右邊,小于或等于這個數的數放到他的左邊;
3.在對左右區間重復第二步,知道個區間只有一個數。
4.如果這個數組有10個數,第二步將執行十次,每次的復雜度為logn,總復雜度為O(nlogn),因為每執行一次區間排序可為數組中一個元素確定該元素在排序后的位置;
注:每走一趟的思維(挖坑填數)如下:
1.i=L;j=R;將基準數挖出形成第一個坑a[i].
2.j–由后向前找比他小的數,直到找到比他小,找到后挖出此數填前一個坑a[i]中。
3.i++由前向后找到比它大的數,找到后也挖出此數填到前一個坑a[j]中。
4.在重復執行2、3兩步,直到i==j,將基準數填入a[i]中。
二、實現代碼:
三、程序運行結果圖:
四、注意事項:
1.每次走完一趟后要確定一個元素在排序后數組中的位置;
2.利用填坑的思維而不是數組元素的交換(在每走一趟的過程中)
喜歡請點贊 謝謝
具體matlab代碼參考:https://download.csdn.net/download/fyf18845165207/10886708
總結
以上是生活随笔為你收集整理的快速排序的C++实现(利用二分分治法)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 有关机器人的会议和论文投稿时间
- 下一篇: s3c2440移植MQTT