注册本站  论坛  繁體中文

电脑技巧
手机 | MP3 | MP4 | 显卡 | 主板 | 显示器 | 光存储 | 笔记本 | 网络设备 | 移动存储 | 数码相机
键鼠 | CPU | 音箱 | GPS | 电视 | 服务器 | 投影机 | 机箱电源 | 品牌电脑 | 办公打印 |
| 网站首页 | Cisco | Windows | Linux | Java | Dotnet | Oracle | 网页设计 | 平面设计 | 安全 | 软件应用 | 电脑维修 | 办公维修 |
您现在的位置: 电脑技巧 >> Dotnet >> C# >> Dotnet正文

C#实现所有经典排序算法

文章来源:blog.csdn.net 作者:李泓甸 更新时间:2008-6-28 20:39:06 【 】 【加入收藏
//选择排序  
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);   
 
    }  
  • 上一篇Dotnet:

  • 下一篇Dotnet:
  • 最 新 热 门
     web.config配置文件中的 元素
     为网站添加业务层
     用SqlDataSource实现DataList嵌套DataList
     Visual Studio 2003插件的编写
     千条DOS命令收藏
     IIS 常见问题
     IIS需要的最小NTFS权限
     优化 .NET的性能
     设计模式与VB .net代码 外观模式,合成模式
     VB.net中介者模式
    最 新 推 荐
     Windows via C/C++ —进程(一)
     C#邮件发送程序
     扩展 ASP.NET 的客户端验证
     实现DataGridView中行的上下移动
     C#中的委托和事件
     与IDE相关的Attribute属性
     C#中using关键字的使用介绍
     C#FileStream复制大文件
     C#实用技巧:轻松实现对文件的操作
     C#实现所有经典排序算法
    相 关 文 章

    用SqlDataSource实现DataList嵌套DataList
    使用VB.net实现sql数据库的备份与恢复代码
    vb实现IP设置
    C#通过ADO.NET建表点实现方法
    VC++实现对文件夹时间的修改
    asp.net+C#实现文件上传实现代码
    C#邮件发送程序
    实现DataGridView中行的上下移动
    C#中的委托和事件
    C#中using关键字的使用介绍

    | 设为首页 | 加入收藏 | 联系站长 | 友情链接 | 版权申明 | 网站公告

     

    Copyright 2006-2008 pcjx.com All Rights Reserved
    电脑技巧 版权所有 粤ICP备06059145号 地图
    本网站所有内容未经许可不得转载或做其他使用