【資料結構】選擇排序!!!
在選擇排序裡面,是將陣列裡面的資料進行遍歷一遍,找到最大的元素,記錄下最大元素的下標,對最大放在合適的位置。
如圖:
實現程式碼:
void selectionSort(int[] list) {
// 需要遍歷獲得最小值的次數
// 要注意一點,當要排序 N 個數,已經經過 N-1 次遍歷後,已經是有序數列
for (int i = 0; i < list.length - 1; i++) {
int temp = 0;
int index = i; // 用來儲存最小值得索引
// 尋找第i個小的數值
for (int j = i + 1; j < list.length; j++) {
if (list[index] > list[j]) {
index = j;
}
}
temp = list[index];
list[index] = list[i];
list[i] = temp;
printAll(list);
}
}
但是,選擇排序在實現上面還是效率不夠高,因為一次遍歷只能找到一個元素。
優化:遍歷一次找到資料裡面的兩個元素,分別找到最小的元素和最小的元素,對最小和最大的元素進行相應位置的交換,那麼在時間複雜度上面就有一定的提高。
如圖:
實現程式碼:
void selectsort(int *arr,size_t size)
{
if(NULL == arr)
return ;
int left = 0;
int right = size;
while(left < right)
{
int i=left;
int Max = left;//定義最大元素和最小元素
int Min = left;
while(i < right-1)
{
if(arr[Max]< arr[i+1])
Max = i+1; //找到最大元素的下標
if(arr[Min] > arr[i+1])
Min = i+1; //找到最小元素的下標
i++;
}
swap(arr[left],arr[Min]); //將最小元素放到合適位置
if(Max == left)
Max = Min; //判斷最小元素的位置是不是在最大元素需要放置的位置
swap(arr[right-1],arr[Max]);
left++;
right--;
}
}
相關文章
- 資料結構32:選擇排序資料結構排序
- 資料結構與演算法——排序演算法-選擇排序資料結構演算法排序
- 演算法與資料結構——選擇排序(c++)演算法資料結構排序C++
- 資料結構學習筆記-簡單選擇排序資料結構筆記排序
- 【圖解資料結構】 一組動畫演示選擇排序圖解資料結構動畫排序
- 資料結構和演算法:03.冒泡、選擇排序資料結構演算法排序
- 重學資料結構和演算法(四)之氣泡排序、插入排序、選擇排序資料結構演算法排序
- 演算法與資料結構系列 ( 三 ) - 選擇排序法- Select Sort演算法資料結構排序
- 看圖輕鬆理解資料結構與演算法系列(選擇排序)資料結構演算法排序
- 從零開始學資料結構和演算法(一)冒泡與選擇排序資料結構演算法排序
- 資料結構與排序資料結構排序
- 選擇結構
- 選擇排序排序
- 順序結構與選擇結構
- 資料結構之計數排序資料結構排序
- 資料結構第10章 排序資料結構排序
- 資料結構(python) —— 【18排序: 桶排序】資料結構Python排序
- switch選擇結構使用
- python的選擇結構Python
- 選擇排序和快速排序排序
- 冒泡、選擇、快排、插入排序—效能簡單測試/rand()邊界值——c++資料結構排序C++資料結構
- js選擇排序JS排序
- 01選擇排序排序
- 選擇排序法排序
- Java 選擇排序Java排序
- 資料結構--排序--插入排序--python語言描述資料結構排序Python
- 選擇排序中交換資料的不同方式出現的不同結果排序
- 資料結構與演算法——排序資料結構演算法排序
- 資料結構第九節(排序(上))資料結構排序
- 單連結串列的排序(插入,選擇,冒泡)排序
- 排序演算法:選擇排序排序演算法
- 排序演算法__選擇排序排序演算法
- 選擇排序和氣泡排序排序
- 氣泡排序與選擇排序排序
- 桶排序 選擇,插入排序排序
- Day12-if選擇結構
- 選擇結構程式設計程式設計
- C語言-選擇結構C語言
- Python(二):選擇結構與迴圈結構Python