c#實現(xiàn)選擇排序的示例
1.工作原理(算法思路)
- 給定一個待排序數(shù)組,找到數(shù)組中最小的那個元素
- 如果最小元素不是待排序數(shù)組的第一個元素,則將其和第一個元素互換
- 在剩下的元素中,重復(fù)1、2過程,直到排序完成。
2.動圖演示

3.C#代碼實現(xiàn)
根據(jù)原理設(shè)計算法:
class Program
{
//選擇排序法
private static void chooseSort(int[] array)
{
//第一個for循環(huán):每一次循環(huán)完成后得到的當前的最大元素都與第i位做交換
for (int i = 0; i < array.Length; i++)
{
//min為最小元素的索引
int min = i;
//第二個for循環(huán):將當前的array[j]與array[min]作比較,如果array[j]更小,則替換min的當前索引
for (int j = i + 1; j < array.Length; j++)
{
if (array[min] > array[j])
{
min = j;
}
}
//當?shù)诙€for循環(huán)完成時,array[min]中存儲的就是當前最小元素
//將array[min]與array[i]交換
int temp = array[i];
array[i] = array[min];
array[min] = temp;
}
}
//打印輸出數(shù)組
private static void printArray(int[] array)
{
foreach (int item in array)
{
Console.Write(item + "\t");
}
Console.WriteLine();
}
static void Main(string[] args)
{
int[] array = new int[10] { 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
printArray(array);
chooseSort(array);
printArray(array);
Console.ReadKey();
}
}
輸出結(jié)果

4.性能分析
1)復(fù)雜度

2)選擇排序法特點
- 執(zhí)行的比較和交換次數(shù)
比較: N*(N-1)/2
交換: N
- 運行時間與輸入無關(guān)
在每一次的for循環(huán)結(jié)束后并不能為下一次的循環(huán)提供有效信息。這種性質(zhì)在某些時候是一種缺陷。在數(shù)組大小相同時,當一個幾乎已經(jīng)有序的數(shù)組使用選擇排序法花費的時間和無序數(shù)組所花費的時間是一致的。
- 數(shù)據(jù)的移動量最少
交換的次數(shù)和數(shù)組的大小呈線性關(guān)系,其他的排序算法對數(shù)據(jù)移動量都是線性對數(shù)級別或平方級別的。
以上就是c#實現(xiàn)選擇排序的示例的詳細內(nèi)容,更多關(guān)于c# 選擇排序的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
WPF實現(xiàn)帶模糊搜索的DataGrid的示例代碼
這篇文章主要為大家詳細介紹了WPF如何實現(xiàn)帶模糊搜索的DataGrid,文中的示例代碼講解詳細,具有一定的借鑒價值,需要的可以參考一下2023-02-02
Unity的BuildPlayerProcessor實用案例深入解析
這篇文章主要為大家介紹了Unity的BuildPlayerProcessor實用案例深入解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-05-05
C#多線程學(xué)習之(五)使用定時器進行多線程的自動管理
這篇文章主要介紹了C#多線程學(xué)習之使用定時器進行多線程的自動管理,實例分析了C#使用timer定時器類實現(xiàn)針對多線程的自動管理功能,非常具有實用價值,需要的朋友可以參考下2015-04-04

