zoukankan      html  css  js  c++  java
  • 快排,堆排 C#实现

            /// <summary>
            
    /// 堆排序
            
    /// </summary>
            
    /// <param name="R"></param>
            public static void HEAPSORT(int[] R)
            {
                
    //建初始大根堆
                for (int i = R.Length / 2 + Convert.ToInt32(Math.IEEERemainder(R.Length, 2)); i > 0; i--)
                {
                    SIFT(R, i 
    - 1, R.Length - 1);
                }
                
    //循环进行交换并重建大根堆
                for (int j = R.Length - 1; j > 0; j--)
                {
                    
    //交换根和无序区最后一个数
                    int t = R[0]; R[0= R[j]; R[j] = t;
                    SIFT(R, 
    0, j - 1);
                }
            }
            
    public static void SIFT(int[] R, int iFrom, int iTo)
            {
                
    int i = iFrom;            //根结点下标
                int j = 2 * iFrom + 1;    //左孩子下标
                int temp = R[i];          //要调整的根结点,假定左右子树已为大根堆
                while (j <= iTo)
                {
                    
    if ((j < iTo) && ((R[j] < R[j + 1])))
                    {
                        j
    ++;//如果右孩子大于左孩子,将j指向右孩子,以便接下来统一处理
                    }
                    
    if ((R[j] > temp))
                    {
                        
    //比根结点大的孩子上移
                        R[i] = R[j];
                        
    //指向下一个子树
                        i = j;
                        j 
    = 2 * i + 1;
                    }
                    
    else
                    {
                        
    break;
                    }
                }
                
    //定位要当初的根结点到正确的位置
                R[i] = temp;
            }


            
    //---------------------------------------------------------------------------------

            
    /// <summary>
            
    /// 快速排序算法
            
    /// </summary>
            
    /// 快速排序为不稳定排序,时间复杂度O(nlog2n),为同数量级中最快的排序方法
            
    /// <param name="arr">划分的数组</param>
            
    /// <param name="low">数组低端上标</param>
            
    /// <param name="high">数组高端下标</param>
            
    /// <returns></returns>
            static int Partition(int[] arr, int low, int high)
            {
                
    //进行一趟快速排序,返回中心轴记录位置
                
    // arr[0] = arr[low];
                int pivot = arr[low];//把中心轴置于arr[0]
                while (low < high)
                {
                    
    while (low < high && arr[high] >= pivot)
                    {
                        
    --high;
                    }
                    Swap(
    ref arr[high], ref arr[low]);//将比中心轴记录小的移到低端
                    while (low < high && arr[low] <= pivot)
                    {
                        
    ++low;
                    }
                    Swap(
    ref arr[high], ref arr[low]);//将比中心轴记录大的移到高端
                    
                }
                arr[low] 
    = pivot; //中心轴移到正确位置
                return low;  //返回中心轴位置
            }
            
    static void Swap(ref int i, ref int j)
            {
                
    int t;
                t 
    = i;
                i 
    = j;
                j 
    = t;
            }
            
    static void QuickSort(int[] arr, int low, int high)
            {
                
    if (low < high - 1)//当 arr[low,high]为空或只一个记录无需排序
                {
                    
    int pivot = Partition(arr, low, high);
                    QuickSort(arr, low, pivot 
    - 1);
                    QuickSort(arr, pivot 
    + 1, high);

                }
            }
  • 相关阅读:
    Windows10 安装 MySQL 并开启远程访问
    Navicat Premium 12 破解教程
    基于 debian9 安装 Windows10 双系统 丢失引导文件的修复办法
    SD从零开始59-61,跨公司的库存转移,Interface 修改,可用性检查和需求传递
    SD从零开始57-58,第三方订单处理,跨公司销售
    SD从零开始55-56, 风险管理, 付款卡
    SD从零开始51-54 信用控制范围, 信用范围数据维护, 自动信用控制, 信用控制-阻止后续功能
    SD从零开始47-50, 装运成本基础、控制、结算, 信用/风险管理概述
    SD从零开始45-46
    SD从零开始41-44
  • 原文地址:https://www.cnblogs.com/tonybinlj/p/1500509.html
Copyright © 2011-2022 走看看