Vijos資料結構基礎C++實驗整理(二)——排序演算法
阿新 • • 發佈:2021-01-16
實驗內容:
用任意一種排序方式給出n個整數按升序排序後的結果(名次排序、及時終止的選擇排序、及時終止的氣泡排序、插入排序)
樣例:
輸入
5
5 3 4 2 1
輸出
1 2 3 4 5
程式碼實現:
#include<iostream>
#include<iterator>
using namespace std;
template<class T>
class Sort {
public:
void selectionSort(T a[], int n) {//及時終止的選擇排序
bool sorted = false;
for (int size = n; (!sorted)&&(size > 1); size--) {
int indexOfMax = 0;
sorted = true;
for (int i = 1; i < size; i++)
if (a[indexOfMax] <= a[i]) indexOfMax = i;
else sorted = false;
swap(a[indexOfMax], a[size - 1]);
}
for (int j = 0; j <n; j++) {//輸出
cout << a[j] << " ";
}
}
bool bubble(T a[], int n) {//及時終止的氣泡排序//主體部分
bool swapped = false;
for(int i=0;i<n-1;i++)
if (a[i] > a[i + 1]) {
swap(a[i], a[i + 1]);
swapped = true;
}
return swapped;
}
void bubbleSort(T a[], int n) {//氣泡排序呼叫部分
for (int i = n; i > 1 && bubble(a, i); i--);
for (int j = 0; j < n; j++) {//輸出
cout << a[j] << " ";
}
}
void insertionSort(T a[], int n) {//插入排序
for (int i = 1; i < n; i++) {
T t = a[i];
int j;
for (j = i - 1; j >= 0 && t < a[j]; j--)
a[j + 1] = a[j];
a[j + 1] = t;
}
for (int j = 0; j < n; j++) {//輸出
cout << a[j] << " ";
}
}
void rearrange(T a[], int n, int r[]) {//名次排序
T* u = new T[n];
for (int i = 0; i < n; i++)
u[r[i]] = a[i];
for (int i = 0; i < n; i++)
a[i] = u[i];
for (int j = 0; j < n; j++) {//輸出
cout << a[j] << " ";
}
delete[] u;
}
private:
};
int main() {
int n;
cin >> n;
int* a = new int[n];
for (int i = 0; i < n; i++) {
cin >> a[i];
}
Sort<int > b;
//b.insertionSort(a, n);
//b.bubbleSort(a, n);
//b.selectionSort(a, n);
int c[] = { 4,3,2,1,0 };//對應5 4 3 2 1 的名次,測試時應輸入5 4 3 2 1
b.rearrange(a, n, c);
delete[] a;
return 0;
}