打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
c#中的排序算法(动态数组ArrayList) - 欢迎来到jay的空间 - 博客园

c#中的排序算法(动态数组ArrayList)

private void button1_Click(object sender, EventArgs e)
        {
            TimeSpan s = new TimeSpan();
            DateTime dt = DateTime.Now;
            SortingAlgorithm sort = new SortingAlgorithm();
            ArrayList iArrary = new ArrayList(1);
            Random r = new Random();
            for (int i = 0; i < 100; i++)
            {
                iArrary.Add(r.Next(1000));
            }
            //int[] iArrary = new int[]{1,5,3,6,10,55,9,2,87,12,34,75,33,47};
            richTextBox1.Text += "未排序数据: ";
            foreach (int i in iArrary)
            {
                richTextBox1.Text += i.ToString() + "   ";
            }
            ///冒泡排序
            sort.BubbleSorter(iArrary);
            richTextBox1.Text += "\n冒泡 排 序: ";
            foreach (int i in iArrary)
            {
                richTextBox1.Text += i.ToString() + "   ";
            }
            ///选择排序
            sort.SelectionSorter(iArrary);
            richTextBox1.Text += "\n选择 排 序: ";
            foreach (int i in iArrary)
            {
                richTextBox1.Text += i.ToString() + "   ";
            }
            ///插入排序
            sort.InsertionSorter(iArrary);
            richTextBox1.Text += "\n插入 排 序: ";
            foreach (int i in iArrary)
            {
                richTextBox1.Text += i.ToString() + "   ";
            }

            ///希尔排序
            sort.ShellSorter(iArrary);
            richTextBox1.Text += "\n希尔 排 序: ";
            foreach (int i in iArrary)
            {
                richTextBox1.Text += i.ToString() + "   ";
            }
            s = DateTime.Now - dt;
            richTextBox1.Text += "\n用时:" + s.TotalMilliseconds + " 毫秒";
        }

/*
 * C#中排序算法
 * 2009年7月27日
 * CEDAR(雪中松)
 */
using System;
using System.Collections.Generic;
using System.Text;
using System.Collections;

namespace HC.Common
{
    public class SortingAlgorithm
    {
        /// <summary>
        /// 冒泡排序
        /// </summary>
        /// <param name="list"></param>
        public void BubbleSorter(ArrayList list)
        {
            int i, j, temp;
            bool done = false;
            j = 1;
            while ((j < list.Count) && (!done))
            {
                done = true;
                for (i = 0; i < list.Count - j; i++)
                {
                    if( Convert.ToInt32(list[i]) >Convert.ToInt32(list[i + 1]))
                    {
                        done = false;
                        temp = Convert.ToInt32(list[i]);
                        list[i] = Convert.ToInt32(list[i + 1]);
                        list[i + 1] = temp;
                    }
                }
                j++;
            }
        }
        /// <summary>
        /// 选择排序
        /// </summary>
        /// <param name="list"></param>
        public void SelectionSorter(ArrayList list)
        {
            int min;
            for (int i = 0; i < list.Count - 1; i++)
            {
                min = i;
                for (int j = i + 1; j < list.Count; j++)
                {
                    if ( Convert.ToInt32(list[j]) <  Convert.ToInt32(list[min]))
                        min = j;
                }

                int t =  Convert.ToInt32(list[min]);
                list[min] =  Convert.ToInt32(list[i]);
                list[i] = t;
            }
        }
        /// <summary>
        /// 插入排序
        /// </summary>
        /// <param name="list"></param>
        public void InsertionSorter(ArrayList list)
        {
            int i, j, temp;
            bool done = false;
            j = 1;
            while ((j < list.Count) && (!done))
            {
                done = true;
                for (i = 0; i < list.Count - j; i++)
                {
                    if ( Convert.ToInt32(list[i]) >  Convert.ToInt32(list[i + 1]))
                    {
                        done = false;
                        temp =  Convert.ToInt32(list[i]);
                        list[i] =  Convert.ToInt32(list[i + 1]);
                        list[i + 1] = temp;
                    }
                }
                j++;
            }
        }
        /// <summary>
        /// 希尔排序
        /// </summary>
        /// <param name="list"></param>
        public void ShellSorter(ArrayList list)
        {
            int inc;
            for (inc = 1; inc <= list.Count / 9; inc = 3 * inc + 1) ;
            for (; inc > 0; inc /= 3)
            {
                for (int i = inc + 1; i <= list.Count; i += inc)
                {
                    int t =  Convert.ToInt32(list[i - 1]);
                    int j = i;
                    while ((j > inc) && ( Convert.ToInt32(list[j - inc - 1]) > t))
                    {
                        list[j - 1] =  Convert.ToInt32(list[j - inc - 1]);
                        j -= inc;
                    }
                    list[j - 1] = t;
                }
            }
        }
    }
}

 

本文来自CSDN博客 :http://blog.csdn.net/xuezhongsong/archive/2009/07/27/4383436.aspx

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
WPF中Image显示本地图片
生成SQL语句分页的通用C#函数
asp.net 将数字转化成大写
VB.NET进制转换(二进制、八进制、十进制)
中文汉字转换成拼音首字 拼音全拼
c#条码打印代码 pplb zpl
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服