C++排序算法之冒泡排序解析
C++冒泡排序
思想
從左到右,相鄰兩數兩兩比較,若下標小的數大于下標大的數則交換,將最大的數放在數組的最后一位(即下標n-1的位置)
采用相同的方法,再次遍歷數組,將第二大的數,放在數組倒數第二的位置(即n-2的位置),以此類推,直到數組有序
優(yōu)化:當數組在整個遍歷過程中沒有發(fā)生交換,說明待排序數組已經有序,此時可以直接結束排序過程(用bool類型變量作標記)。
代碼
#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;
}解析
時間復雜度:
最好時間復雜度(有序情況):O(n)
比較n-1次,交換0次 故最好時間復雜度為O(n)
最壞時間復雜度(逆序情況):O(n2)
第一次排序時是n個元素,比較n-1次,交換n-1次
第二次排序時是n-1個元素,比較n-2次,交換n-2次
...
第n-1次排序時是2個元素,比較1次,交換1次
第n次排序時是1個元素,比較0次,交換0次
故選擇排序時間復雜度為O((1+2+3+...+n-1)*2)=O(n*(n-1))=O(n2)
空間復雜度:
在原數組上操作,即使用了常數級空間O(1)
到此這篇關于C++排序算法之冒泡排序解析的文章就介紹到這了,更多相關C++冒泡排序內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
IOS開發(fā)之UIScrollView實現圖片輪播器的無限滾動
這篇文章主要介紹了IOS開發(fā)之UIScrollView實現圖片輪播器的無限滾動的相關資料,需要的朋友可以參考下2017-07-07

