C#實現所有經典排序演算法

來源:互聯網
上載者:User

C#實現所有經典排序演算法

//選擇排序  
class SelectionSorter  
{  
    private int min;  
    public void Sort(int[] arr)  
    {  
        for (int i = 0; i < arr.Length - 1; ++i)  
        {  
            min = i;  
            for (int j = i + 1; j < arr.Length; ++j)  
            {  
                if (arr[j] < arr[min])  
                    min = j;  
            }  
            int t = arr[min];  
            arr[min] = arr[i];  
            arr[i] = t;  
        }  
    }  
    static void Main(string[] args)  
    {  
        int[] array = new int[] { 1, 5, 3, 6, 10, 55, 9, 2, 87, 12, 34, 75, 33, 47 };  
        SelectionSorter s = new SelectionSorter();  
        s.Sort(array);  
        foreach (int m in array)  
            Console.WriteLine("{0}", m);  
    }  
}  
//冒泡排序  
class EbullitionSorter  
{  
    public void Sort(int[] arr)  
    {  
        int i, j, temp;  
        bool done = false;  
        j = 1;  
        while ((j < arr.Length) && (!done))//判斷長度  
        {  
            done = true;  
            for (i = 0; i < arr.Length - j; i++)  
            {  
                if (arr[i] > arr[i + 1])  
                {  
                    done = false;  
                    temp = arr[i];  
                    arr[i] = arr[i + 1];//交換資料  
                    arr[i + 1] = temp;  
                }  
            }  
            j++;  
        }  
    }  
 
    static void Main(string[] args)  
    {  
        int[] array = new int[] { 1, 5, 3, 6, 10, 55, 9, 2, 87, 12, 34, 75, 33, 47 };  
        EbullitionSorter e = new EbullitionSorter ();  
        e.Sort(array);  
        foreach (int m in array)  
            Console.WriteLine("{0}", m);  
 
    }  
}  
//快速排序  
class QuickSorter  
{  
    private void swap(ref int l, ref int r)  
    {  
        int temp;  
        temp = l;  
        l = r;  
        r = temp;  
    }  
    public void Sort(int[] list, int low, int high)  
    {  
        int pivot;//儲存分支點  
        int l, r;  
        int mid;  
        if (high <= low)  
            return;  
        else if (high == low + 1)  
        {  
            if (list[low] > list[high])  
                swap(ref list[low], ref list[high]);  
            return;  
        }  
        mid = (low + high) >> 1;  
        pivot = list[mid];  
        swap(ref list[low], ref list[mid]);  
        l = low + 1;  
        r = high;  
        do 
        {  
            while (l <= r && list[l] < pivot)  
                l++;  
            while (list[r] >= pivot)  
                r--;  
            if (l < r)  
                swap(ref list[l], ref list[r]);  
        } while (l < r);  
        list[low] = list[r];  
        list[r] = pivot;  
        if (low + 1 < r)  
            Sort(list, low, r - 1);  
        if (r + 1 < high)  
            Sort(list, r + 1, high);  
    }  
 
 
 
    static void Main(string[] args)  
    {  
        int[] iArrary = new int[] { 1, 5, 3, 6, 10, 55, 9, 2, 87, 12, 34, 75, 33, 47 };  
        QuickSorter q = new QuickSorter();  
        q.Sort(iArrary, 0, 13);  
        for (int m = 0; m <= 13; m++)  
            Console.WriteLine("{0}", iArrary[m]);  
    }  
}  
//插入排序  
public class InsertionSorter  
{  
    public void Sort(int[] arr)  
    {  
        for (int i = 1; i < arr.Length; i++)  
        {  
            int t = arr[i];  
            int j = i;  
            while ((j > 0) && (arr[j - 1] > t))  
            {  
                arr[j] = arr[j - 1];//交換順序  
                --j;  
            }  
            arr[j] = t;  
        }  
    }  
    static void Main(string[] args)  
    {  
        int[] array = new int[] { 1, 5, 3, 6, 10, 55, 9, 2, 87, 12, 34, 75, 33, 47 };  
        InsertionSorter i = new InsertionSorter();  
        i.Sort(array);  
        foreach (int m in array)  
            Console.WriteLine("{0}", m);   
    }  
}  
//希爾排序  
public class ShellSorter  
{  
    public void Sort(int[] arr)  
    {  
        int inc;  
        for (inc = 1; inc <= arr.Length / 9; inc = 3 * inc + 1) ;  
        for (; inc > 0; inc /= 3)  
        {  
            for (int i = inc + 1; i <= arr.Length; i += inc)  
            {  
                int t = arr[i - 1];  
                int j = i;  
                while ((j > inc) && (arr[j - inc - 1] > t))  
                {  
                    arr[j - 1] = arr[j - inc - 1];//交換資料  
                    j -= inc;  
                }  
                arr[j - 1] = t;  
            }  
        }  
    }  
 
    static void Main(string[] args)  
    {  
        int[] array = new int[] { 1, 5, 3, 6, 10, 55, 9, 2, 87, 12, 34, 75, 33, 47 };  
        ShellSorter s = new ShellSorter();  
        s.Sort(array);  
        foreach (int m in array)  
            Console.WriteLine("{0}", m);   
 
    }  

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.