zoukankan      html  css  js  c++  java
  • 最小堆排序

    /// <summary>
        /// 最小堆排序,把所有的排序元素放在数组中。构成一个完全二叉树。
        /// </summary>
        public class MyHeapSort
        {
            /// <summary>
            /// 创建最小堆
            /// </summary>
            /// <param name="list"></param>
            /// <param name="low"></param>
            /// <param name="high"></param>
            public void CreateHeap(List<int> list,int low,int high)
            {
                int temp = 0;
                int k = 0;
                //从第一个非叶子节点开始,一直到到跟节点
                for (int i = list.Count / 2; i >= low;i-- )
                {
                    k = i;
                    int j = 2 * k + 1;//左子节点
                    temp = list[k];
                    while (j <= high)
                    {
                        //找到左右节点中较小的节点
                        if (j<high&&j+1<high&&
                            list[j] > list[j + 1])
                        {
                            j++;
                        }
                        //父节点和较小的子节点比较,如果父节点大,则交换位置
                        if (temp > list[j])
                        {
                            list[k] = list[j];
                            k = j;
                            j = 2 * k + 1;//循环到下一级节点
                        }
                        else
                        {
                            j = high + 1;//跳出循环
                        }
                    }
                    list[k] = temp;//放置父节点
                }
            }

            public void HeapSort()
            {
                List<int> l = new List<int>();
                l.Add(30);
                l.Add(10);
                l.Add(5);
                l.Add(4);
                l.Add(9);
                l.Add(2);
                l.Add(6);
                CreateHeap(l, 0, 6);
                StringBuilder sb = new StringBuilder();
                for (int i = 0; i < l.Count; i++)
                {
                    sb.AppendFormat("{0},", l[i]);
                }
                MessageBox.Show(sb.ToString());
            }
            
  • 相关阅读:
    Executors几种常用的线程池性能比较
    mac上利用minikube搭建kubernetes(k8s)环境
    基于redis的分布式锁二种应用场景
    alibaba canal安装笔记
    开源流媒体服务器SRS学习笔记(4)
    开源流媒体服务器SRS学习笔记(3)
    pygame-KidsCanCode系列jumpy-part18-背景滚动
    开源流媒体服务器SRS学习笔记(2)
    开源流媒体服务器SRS学习笔记(1)
    pygame-KidsCanCode系列jumpy-part17-mask-collide碰撞检测
  • 原文地址:https://www.cnblogs.com/363546828/p/3981883.html
Copyright © 2011-2022 走看看