C++排序算法之冒泡排序解析
C++冒泡排序
思想
從左到右,相鄰兩數(shù)兩兩比較,若下標(biāo)小的數(shù)大于下標(biāo)大的數(shù)則交換,將最大的數(shù)放在數(shù)組的最后一位(即下標(biāo)n-1的位置)
采用相同的方法,再次遍歷數(shù)組,將第二大的數(shù),放在數(shù)組倒數(shù)第二的位置(即n-2的位置),以此類推,直到數(shù)組有序
優(yōu)化:當(dāng)數(shù)組在整個遍歷過程中沒有發(fā)生交換,說明待排序數(shù)組已經(jīng)有序,此時可以直接結(jié)束排序過程(用bool類型變量作標(biāo)記)。
代碼
#include<iostream> #include<vector> using namespace std; void bubbleSort(vector<int>&vec, int n) { for (int j = n; j >= 1; j--) { bool flag = true; for (int i = 0; i < j - 1; i++) { if (vec[i] > vec[i + 1]) { swap(vec[i], vec[i + 1]); flag = false; } } if (flag) return; } } int main() { vector<int>vec = { 2,3,5,8,9,7,4,6,1 }; bubbleSort(vec, vec.size()); for (auto it : vec) { cout << it << " "; } return 0; }
解析
時間復(fù)雜度:
最好時間復(fù)雜度(有序情況):O(n)
比較n-1次,交換0次 故最好時間復(fù)雜度為O(n)
最壞時間復(fù)雜度(逆序情況):O(n2)
第一次排序時是n個元素,比較n-1次,交換n-1次
第二次排序時是n-1個元素,比較n-2次,交換n-2次
...
第n-1次排序時是2個元素,比較1次,交換1次
第n次排序時是1個元素,比較0次,交換0次
故選擇排序時間復(fù)雜度為O((1+2+3+...+n-1)*2)=O(n*(n-1))=O(n2)
空間復(fù)雜度:
在原數(shù)組上操作,即使用了常數(shù)級空間O(1)
到此這篇關(guān)于C++排序算法之冒泡排序解析的文章就介紹到這了,更多相關(guān)C++冒泡排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
IOS開發(fā)之UIScrollView實現(xiàn)圖片輪播器的無限滾動
這篇文章主要介紹了IOS開發(fā)之UIScrollView實現(xiàn)圖片輪播器的無限滾動的相關(guān)資料,需要的朋友可以參考下2017-07-07