目录
优先级队列插入操作算法
优先级队列中插入操作的算法
首页 后端开发 C++ C/C++中的优先队列介绍

C/C++中的优先队列介绍

Sep 13, 2023 pm 05:21 PM
编程 (programming) c语言 (c language) 优先队列 (priority queue)

优先级队列是一种队列,其中根据分配给它们的优先级插入或删除元素,其中优先级是范围在 0-10 之间的整数值,其中 0 表示具有最高优先级的元素,10 表示具有最高优先级的元素优先级最低的元素。实现优先级队列遵循两条规则:

  • 具有最高优先级的数据或元素将在具有最低优先级的数据或元素之前执行。
  • 如果两个元素具有相同的优先级,则它们将按照它们添加到列表中的顺序执行。

有多种可用的数据结构可用于实现优先级队列如堆栈、队列和链表。在本文中,我们将解释队列数据结构。有两种方法可以用来实现优先级队列,例如 -

  • 在单个数组中维护多个优先级的队列

    一种方法实现优先级队列就是为每个优先级维护一个队列。我们可以将这些多个队列存储在一个数组中,其中每个队列都有两个指针,即 Front 和 Rear。在队列中,Front指针用于向队列中插入元素,每当插入元素时它就加1;另一个指针是rear指针,用于从队列中删除或移除元素,每当元素插入时它就减1被从队列中删除。最后,通过两个指针的位置我们还可以确定队列中元素的数量。

C/C++中的优先队列介绍

注意 - 如果每个队列的大小相同,那么我们可以创建一个二维数组,而不是创建多个一维数组维数组。

优先级队列插入操作算法

1

2

3

4

5

6

7

8

9

10

11

12

13

insert(queue, data, priority)

   If(queue->Rear[priority] = MAX-1 AND queue->Front[priority] = 0) OR (queue->Rear[priority] +1 =queue->Front[priority])

      Print Overflow

   End

   IF queue->Rear[priority - 1] = MAX-1

      Set queue->Rear[priority - 1] = 0

   Else

      Set queue->Rear[priority] = queue->Rear[priority - 1] +1

   End

      Set queue->CQueue[priority - 1] [queue->Rear[priority - 1] = data

   IF queue->Front[priority - 1] = -1

      Set queue->Front[priority - 1] = 0

End

登录后复制

优先级队列中插入操作的算法

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

delete(queue)

   Set flag = 0, priority = 0

      While priority <= MAX-1

         IF NOT queue->Front[priority] = -1

            Set flag = 1

            Set value = queue->CQueue[priority][queue->Front[priority]]

            IF queue->Front[priority] = queue->Rear[priority]

               Set queue->Front[priority] = queue->Rear[priority] = -1

            Else

            IF queue->Front[priority] = MAX-1

               Set queue->Front[priority] = 0

            Else

               Set queue->Front[priority] = queue->Front[priority] + 1

            End

         End

      Break

   End

   Set priority = priority +

End

If flag = 0

   Print underflow

Else

   Return value

End

登录后复制

以上是C/C++中的优先队列介绍的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

在C语言中的指定初始化器 在C语言中的指定初始化器 Sep 01, 2023 am 08:49 AM

在C语言中的指定初始化器

C/C++中的优先队列介绍 C/C++中的优先队列介绍 Sep 13, 2023 pm 05:21 PM

C/C++中的优先队列介绍

在C语言中,宏的可变长度参数 在C语言中,宏的可变长度参数 Aug 27, 2023 pm 10:49 PM

在C语言中,宏的可变长度参数

在C语言中,卫生宏 在C语言中,卫生宏 Sep 03, 2023 pm 06:09 PM

在C语言中,卫生宏

在C语言中,什么是内联函数? 在C语言中,什么是内联函数? Sep 08, 2023 am 11:21 AM

在C语言中,什么是内联函数?

在C/C++中的数组? 在C/C++中的数组? Sep 20, 2023 pm 08:25 PM

在C/C++中的数组?

暴风雨数字 暴风雨数字 Aug 26, 2023 am 09:41 AM

暴风雨数字

李彦宏重提'车水马龙”,称AI会给人类创造更多机会 李彦宏重提'车水马龙”,称AI会给人类创造更多机会 May 25, 2023 pm 10:05 PM

李彦宏重提'车水马龙”,称AI会给人类创造更多机会

See all articles