对于数组 [3, 2, 1, 4, 5]
, 排序后为:[1, 2, 3, 4, 5]
。
采用 冒泡排序:
最坏时间复杂度 | {\displaystyle O(n^{2})}data:image/s3,"s3://crabby-images/02c55/02c5511d35cbc9dd32857c85fb9e2436296c5990" alt="O(n^{2})" |
---|
最优时间复杂度 | {\displaystyle O(n)}data:image/s3,"s3://crabby-images/d82ed/d82ed9591526d70f9d73370be5b6183712f7d435" alt="O(n)" |
---|
平均时间复杂度 | {\displaystyle O(n^{2})}data:image/s3,"s3://crabby-images/02c55/02c5511d35cbc9dd32857c85fb9e2436296c5990" alt="O(n^{2})" |
---|
空间复杂度 | 总共{\displaystyle O(n)} ,需要辅助空间{\displaystyle O(1)}data:image/s3,"s3://crabby-images/e60a3/e60a359992310acb2af51fda18c119be190ca0ab" alt="O(1)" |
---|
class Solution {
public:
/**
* @param A: an integer array
* @return: nothing
*/
void sortIntegers(vector<int> &A) {
// write your code here
if(A.size()!=0){
for(int i=0;i<A.size()-1;i++){
for(int j=0;j<A.size()-1;j++){
swap(A[j],A[j+1]);
}
}
}
}
void swap(int &a,int &b){
if(a>b){
a^=b;
b^=a;
a^=b;
}
}
};