1. 程式人生 > 其它 >Vijos資料結構基礎C++實驗整理(二)——排序演算法

Vijos資料結構基礎C++實驗整理(二)——排序演算法

技術標籤:資料結構c++排序演算法演算法

實驗內容:
用任意一種排序方式給出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; }