亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++實現(xiàn)選擇性排序(SelectionSort)

 更新時間:2020年04月26日 09:56:39   作者:kevinmeanscool  
這篇文章主要為大家詳細介紹了C++實現(xiàn)選擇性排序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

“選擇性排序”是數(shù)列排序的算法之一。
其思路引點來源于經(jīng)典的“可樂雪碧問題”

“現(xiàn)有兩杯飲料,一杯是雪碧,一杯是可樂,試問如何可以將兩杯飲料交換?”
“答:最簡單的解決方案就是利用一個空杯,創(chuàng)造一個緩存區(qū)?!?/p>

選擇性排序就是利用線性搜索數(shù)列并找到當前最小值,通過不斷的將當前最小值放置當前位置索引的算法。

1、算法思路

這是一個未排序的數(shù)列。

首先,線性搜索數(shù)列,找到最小值。

將最小值替換為列中左端的數(shù)字并進行排序,如果最小值已經(jīng)在左端,則不執(zhí)行任何操作。

重復(fù)相同操作,直到所有的數(shù)字都被排序。

3、動畫演示

4、代碼清單及其測試結(jié)果

#include <iostream>
template <class T>

int getSizeOfArray(T& ss){
 return sizeof(ss)/ sizeof(ss[0]);
}

void selectionSort(int * ss,int size){
 for(int i=0;i<size-1;i++){
 int minimalIndex = i;//初始化當前范圍內(nèi)最小值索引
 for(int j=i+1;j<size;j++){//查找當前范圍內(nèi)最小值索引
  if(ss[j]<ss[minimalIndex]){
  minimalIndex = j;
  }
 }
 if(minimalIndex!=i){//如果當前范圍內(nèi)最小值索引不為初始化索引,才進行交換
  int cup = 0;
  cup = ss[i];
  ss[i] = ss[minimalIndex];
  ss[minimalIndex] = cup;
 }
 }
}


int main() {
 using namespace std;

 int ss[] = {2,3,5,1,0,8,6,9,7};
 int size = getSizeOfArray(ss);

 cout<< "原數(shù)列:";

 for(int i = 0;i<size;i++)
 {
 cout<< ss[i] << " ";
 }

 cout<< "\n" << "選擇性排序后:";

 selectionSort(ss,size);

 for(int i = 0;i<size;i++)
 {
 cout<< ss[i] << " ";
 }

 return 0;
}

6. 算法分析

時間復(fù)雜度

選擇排序的交換操作介于 0 和 (n - 1) 次之間。選擇排序的比較操作為 n (n - 1) / 2 次之間。選擇排序的賦值操作介于 0 和 3 (n - 1) 次之間。
比較次數(shù)O(n^2),比較次數(shù)與關(guān)鍵字的初始狀態(tài)無關(guān),總的比較次數(shù)N=(n-1)+(n-2)+…+1=n*(n-1)/2。交換次數(shù)O(n),最好情況是,已經(jīng)有序,交換0次;最壞情況交換n-1次,逆序交換n/2次。交換次數(shù)比冒泡排序少多了,由于交換所需CPU時間比比較所需的CPU時間多,n值較小時,選擇排序比冒泡排序快。

穩(wěn)定性

選擇排序是給每個位置選擇當前元素最小的,比如給第一個位置選擇最小的,在剩余元素里面給第二個元素選擇第二小的,依次類推,直到第n-1個元素,第n個元素不用選擇了,因為只剩下它一個最大的元素了。那么,在一趟選擇,如果一個元素比當前元素小,而該小的元素又出現(xiàn)在一個和當前元素相等的元素后面,那么交換后穩(wěn)定性就被破壞了。比較拗口,舉個例子,序列5 8 5 2 9,我們知道第一遍選擇第1個元素5會和2交換,那么原序列中兩個5的相對前后順序就被破壞了,所以選擇排序是一個不穩(wěn)定的排序算法。 [1]

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C語言超細致講解循環(huán)語句

    C語言超細致講解循環(huán)語句

    我們說到當滿足特定條件時,就會執(zhí)行if語句或者switch語句后面的語句,否則不執(zhí)行,但是這只能執(zhí)行一次,在日常生活中,有些事情是需要重復(fù)去做的,C語句就為此引入了循環(huán)語句。所以今天繼續(xù)為大家分享C語言循環(huán)家族
    2022-05-05
  • 一起來學(xué)習C語言的輸入和輸出

    一起來學(xué)習C語言的輸入和輸出

    這篇文章主要為大家詳細介紹了C語言的輸入和輸出,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • 深度剖析C++中的異常機制

    深度剖析C++中的異常機制

    異常是面向?qū)ο笳Z言常用的一種處理錯誤的方式,當一個函數(shù)發(fā)現(xiàn)自己無法處理的錯誤時就可以拋出異常,本文我們將對C++ 異常機制進行深入剖析,感興趣的同學(xué)跟著小編一起來看看吧
    2023-07-07
  • C/C++ 中怎樣使用SetConsoleTextAttribute()函數(shù)來控制輸出字符的顏色

    C/C++ 中怎樣使用SetConsoleTextAttribute()函數(shù)來控制輸出字符的顏色

    這篇文章主要介紹了C/C++ 中如何使用SetConsoleTextAttribute()函數(shù)來控制輸出字符的顏色,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • C語言中變量與其內(nèi)存地址對應(yīng)的入門知識簡單講解

    C語言中變量與其內(nèi)存地址對應(yīng)的入門知識簡單講解

    這篇文章主要介紹了C語言中變量與其內(nèi)存地址對應(yīng)的入門知識簡單講解,同時這也是掌握指針部分知識的基礎(chǔ),需要的朋友可以參考下
    2015-12-12
  • C++獲取字符串長度的幾個函數(shù)方式

    C++獲取字符串長度的幾個函數(shù)方式

    這篇文章主要介紹了C++獲取字符串長度的幾個函數(shù)方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • C語言實現(xiàn)從文件讀入一個3*3數(shù)組,并計算每行的平均值

    C語言實現(xiàn)從文件讀入一個3*3數(shù)組,并計算每行的平均值

    今天小編就為大家分享一篇C語言實現(xiàn)從文件讀入一個3*3數(shù)組,并計算每行的平均值,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • C語言實現(xiàn)學(xué)生信息管理系統(tǒng)(單鏈表)

    C語言實現(xiàn)學(xué)生信息管理系統(tǒng)(單鏈表)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • C語言用棧和隊列實現(xiàn)的回文檢測功能示例

    C語言用棧和隊列實現(xiàn)的回文檢測功能示例

    這篇文章主要介紹了C語言用棧和隊列實現(xiàn)的回文檢測功能,結(jié)合具體實例形式分析了C語言棧和隊列的定義及使用棧和隊列進行回文檢測的操作技巧,需要的朋友可以參考下
    2017-06-06
  • 詳解C++的靜態(tài)內(nèi)存分配與動態(tài)內(nèi)存分配

    詳解C++的靜態(tài)內(nèi)存分配與動態(tài)內(nèi)存分配

    內(nèi)存分配 (Memory Allocation) 是指為計算機程序或服務(wù)分配物理內(nèi)存空間或虛擬內(nèi)存空間的一個過程,本文主要介紹了C++的靜態(tài)內(nèi)存分配與動態(tài)內(nèi)存分配,感興趣的同學(xué)可以參考閱讀
    2023-06-06

最新評論