当前位置: 首页>>代码示例>>C#>>正文


C# PriorityQueue.buildHeap方法代码示例

本文整理汇总了C#中PriorityQueue.buildHeap方法的典型用法代码示例。如果您正苦于以下问题:C# PriorityQueue.buildHeap方法的具体用法?C# PriorityQueue.buildHeap怎么用?C# PriorityQueue.buildHeap使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在PriorityQueue的用法示例。


在下文中一共展示了PriorityQueue.buildHeap方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: Main

    public static void Main()
    {
        int T = int.Parse(Console.ReadLine());
        while (T--> 0)
        {
            string[] tokens = Console.ReadLine().Split();
            int n = int.Parse(tokens[0]);
            int m = int.Parse(tokens[1]);
            tokens = Console.ReadLine().Split();
            Queue<PrintItem> queue = new Queue<PrintItem>();
            PriorityQueue priority_queue = new PriorityQueue();

            for (int i = 0; i < n; i++)
            {
                int pr = int.Parse(tokens[i]);
                PrintItem item = new PrintItem(i, pr);
                queue.Enqueue(item);
                priority_queue.Enqueue(item);
            }
            priority_queue.buildHeap();

            int count = 0;
            PrintItem highPItem = priority_queue.extractMin(); ;
            while (queue.Count > 0)
            {
                PrintItem item = queue.Dequeue();
                if (item.Priority == highPItem.Priority)
                { // add its print time
                    count++;
                    if (item.Index == m)
                        break;
                    highPItem = priority_queue.extractMin();
                }
                else // we did not get high priority item push into queue
                {
                    queue.Enqueue(item);
                }
            }
            Console.WriteLine(count);
        }
    }
开发者ID:Mareeswaran38,项目名称:Problem-Solving,代码行数:41,代码来源:1840_PQUEUE.cs


注:本文中的PriorityQueue.buildHeap方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。