博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C# 插入排序 冒泡排序 选择排序 高速排序 堆排序 归并排序 基数排序 希尔排序...
阅读量:6243 次
发布时间:2019-06-22

本文共 4497 字,大约阅读时间需要 14 分钟。

C# 插入排序 冒泡排序 选择排序 高速排序 堆排序 归并排序 基数排序 希尔排序
以下列出了数据结构与算法的八种基本排序:插入排序 冒泡排序 选择排序 高速排序 堆排序 归并排序 基数排序 希尔排序,然后是測试的样例。代码位置:http://download.csdn.net/detail/luozuolincool/8040027
排序类:
public class Sortings
    {
        //插入排序
        public void insertSort(int[] array)
        {
            int temp = 0;
            int index = 0;
            for (int i = 0; i < array.Length; i++)
            {
                for (int j = 0; j < i; j++)
                {
                    if (array[i] < array[j])//从j到i之间的数总体右移动。将i数据放到j位置
                    {
                        index = i;
                        temp = array[i];
                        while (index > j)
                        {
                            array[index] = array[index - 1];
                            index--;
                        }
                        array[j] = temp;
                        break;
                    }
                }
            }
            printArray(array, "插入排序:");
        }
        public void printArray(int[] array, String type)
        {
            Console.WriteLine(type);
            for (int i = 0; i < array.Length; i++)
            {
                Console.Write(array[i] + ",");
            }
            Console.WriteLine();
        }
        //冒泡排序
        public void bubbleSort(int[] array)
        {
            int temp = 0;
            bool exchanged = true;
            for (int i = 0; i < array.Length; i++)
            {
                if (!exchanged)
                    break;
                for (int j = array.Length - 1; j > i; j--)
                {
                    exchanged = false;
                    if (array[j] < array[j - 1])//后面的数比前面的小就交换
                    {
                        temp = array[j];
                        array[j] = array[j - 1];
                        array[j - 1] = temp;
                        exchanged = true;
                    }
                }
            }
            printArray(array, "冒泡排序:");
        }
        //选择排序:从前到后依次选择最小的放在最前面,第二小的放在第二个位置
        public void selectionSort(int[] array)
        {
            int minIndex = 0;
            int temp = 0;
            for (int i = 0; i < array.Length; i++)
            {
                minIndex = i;
                for (int j = i; j < array.Length; j++)
                {
                    if (array[j] < array[minIndex])
                        minIndex = j;
                }
                //将i到j之间最小的数放到位置i
                temp = array[minIndex];
                array[minIndex] = array[i];
                array[i] = temp;
            }
            printArray(array, "选择排序:");
        }
        //高速排序
        public void quickSort(int[] array)
        {
            quicksort1(array, 0, array.Length - 1);
            printArray(array, "高速排序:");
        }
        public void quicksort1(int[] array, int start, int end)
        {
            if (start >= end)
                return;
            int i = start, j = end;
            int k = array[i];
            while (i < j)
            {
                while (array[j] >= k && i < j)
                    j--;
                array[i] = array[j];
                while (array[i] < k && i < j)
                    i++;
                array[j] = array[i];
            }
            array[i] = k;
            quicksort1(array, start, i -1);
            quicksort1(array, i +1, end);
        }
        //堆排序
        public void stackSort(int[] array)
        {
            MyHeap h = new MyHeap();
            h.buildHeap(array);
            h.HeapSort();
            h.printHeap();
        }
        //归并排序
        public void mergeSort(int[] array)
        {
            mergeSort1(array, 0, array.Length - 1);
            printArray(array, "归并:");
        }
        private void mergeSort1(int[] array ,int start,int end)
        {
            if (start >= end)
                return;
            mergeSort1(array, start, (start+end) / 2);
            mergeSort1(array, (start + end) / 2+1,end);
            merge(array, start, (start + end) / 2, end);
            
        }
        private void merge(int[] array,int start,int mid,int end)
        {
            Queue<int> q = new Queue<int>();
            int i = start, j = mid + 1;
            while (i <=mid && j <=end)
            {
                if (array[i] < array[j])
                {
                    q.Enqueue(array[i]);
                    i++;
                }
                else
                {
                    q.Enqueue(array[j]);
                    j++;
                }
            }
            while (i <= mid)
                q.Enqueue(array[i++]);
            while (j <= end)
                q.Enqueue(array[j++]);
           
            for (i = start; i <= end; i++)
                array[i] = q.Dequeue();
        }
        //基数排序
        public void radixSort(int[] array)
        {
            int maxlength=0;//数据最大位数
            //申请空间用于存放数据
            List<List<int>> lists=new List<List<int>>();
            //申请10个桶,用于存放0-9
            for (int i = 0; i < 10; i++)
                lists.Add(new List<int>());
            //获取数据的最大位数
            for (int i = 0; i < array.Length; i++)
                maxlength = maxlength < array[i].ToString().Length ?

array[i].ToString().Length : maxlength;

            for (int i = 0; i < maxlength; i++)
            {
                //数据入桶
                for (int j = 0; j < array.Length; j++)
                {
                    lists[array[j] / (int)(Math.Pow(10, i)) - array[j] / (int)(Math.Pow(10, i+1))*10].Add(array[j]);
                }
                int t = 0;
                //将桶里面的数据又一次放入数组
                for (int k = 0; k < 10; k++)
                {
                    
                    foreach (int item in lists[k])
                        array[t++] = item;
                }
                //清空桶里面的数据
                for (int k = 0; k < 10; k++)
                {
                    lists[k].Clear();
                }
            }
            printArray(array, "基数排序");
        }
        //希尔排序
        public void shellSort(int[] array)
        {
            int step = array.Length / 2;
            while (step > 0)
            {
                shellInsert(array, step);
                Console.WriteLine();
                printArray(array, "希尔");
                step = step / 2;
            }
            printArray(array, "希尔");
        }
        private void shellInsert(int[] array,int step)
        {
            int temp = 0;
            int index = 0;
            for (int i = 0; i < array.Length; i=i+step)
            {
                for (int j = 0; j < i; j=j+step)
                {
                    if (array[i] < array[j])//从j到i之间的数总体右移动,将i数据放到j位置
                    {
                        index = i;
                        temp = array[i];
                        while (index > j)
                        {
                            array[index] = array[index - 1];
                            index--;
                        }
                        array[j] = temp;
                        break;
                    }
                }
            }
        }
    }

測试代码:
 static void Main(string[] args)
        {
            int[] array = { 12,3,23,4,21,44,2,3,11};
            Console.WriteLine("待排序数组:");
            for (int i = 0; i < array.Length; i++)
            {
                Console.Write(array[i]+",");
            }
            Console.WriteLine();
           // insertSort(array);
           // bubbleSort(array);
           // selectionSort(array);
          //  (new Sortings()).quickSort(array);
          //  (new Sortings()).stackSort(array);
           // (new Sortings()).mergeSort(array);
            //(new Sortings()).shellSort(array);
            (new Sortings()).radixSort(array);
            Console.Read();
        }

转载地址:http://oqsia.baihongyu.com/

你可能感兴趣的文章
【RMAN】使用RMAN duplicate复制同机数据库
查看>>
概率论快速学习03:概率公理补充
查看>>
C++ 对象的内存布局(上)
查看>>
向Java开发者介绍Scala
查看>>
【软考点点】计算机基础知识
查看>>
hdu2066一个人的旅行(多源点多汇点的最短路径问题)
查看>>
老猪带你玩转android自定义控件一——打造最简单viewpagerindicator
查看>>
【hibernate框架】性能优化之list_iterate的不同之处
查看>>
block高级功能
查看>>
把钱投资自己的头脑上(一)
查看>>
iOS调试奇巧淫技(二)之LLDB
查看>>
[LeetCode]173.Binary Search Tree Iterator
查看>>
整合大量开源库项目(五)跳动的TextView JumpingBeans,良好体验的滚动栏ConvenientBanner...
查看>>
some utility discovered by Linux yum search all tcp, epel.repo
查看>>
SecureCRT连接ubuntu时,中文显示乱码的解决方法
查看>>
quartz---我为什么要使用quartz
查看>>
Mybatis参数传递
查看>>
Android 6.0 在运行时请求权限
查看>>
ES6语法(三) 对象
查看>>
Swift4 func
查看>>