priorityqueuejava 优先队列(priority queue)中,提取第二优先级的值并删除,但是不删除第一优先值的数,怎么实现?

priorityqueue  时间:2021-06-22  阅读:()

求大家帮忙 关于C语言里的queue

这是链表的,部分是c++的输入输出,改一下cout,cin换成printf,scanf就行了 #include #include #define MAX 30 using namespace std; typedef struct pqueue { char str[MAX]; int priority; pqueue* next; }pqueue; int enqueuepriority(pqueue *&pq, char str[MAX], int priority) { if(priority>0) { pqueue *p=(pqueue*)malloc(sizeof(pqueue)); for(int i=0;istr[i]=str[i]; p->priority=priority; p->next=pq->next; pq->next=p; return 1; } else return 0; } char* dequeue(pqueue *&pq) { pqueue *p; if(pq->next!=NULL) { p=pq->next; pq->next=pq->next->next; return p->str; } else return ""; } int main() { cout<<"(1) Enqueue (single)"<next=NULL; while(re!=5) { cout<<"Choose an action:"; cin>>re; switch(re) { case 1: cout<<"Enter a name to save and its priority"<next!=NULL) { printf("%s ",dequeue(pq)); } break; case 5: break; default: cout<<"INPUT ERROR!!"<什么是优先队列?优先队列(priority queue)普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头删除。

在优先队列中,元素被赋予优先级。

当访问元素时,具有最高优先级的元素最先删除。

优先队列具有最高进先出 (largest-in,first-out)的行为特征。

java 优先队列(priority queue)中,提取第二优先级的值并删除,但是不删除第一优先值的数,怎么实现?

你要的是这样的效果么 public?static?void?main(String[]?args)?{ ??PriorityQueue?pq?=?new?PriorityQueue(); ??pq.add(5); ??pq.add(2); ??pq.add(3); ??pq.add(4); ??System.out.println("取出了"+pq.poll()+",队列剩余"+Arrays.toString(pq.toArray())); ??/** ???*?假设3是我不满意的值,我要取到3后面的值 ???*/ ??if(pq.peek()==3){ ???System.out.println("3真不是我想要的,我可以接着往下处理么?ok,将3先保留吧"); ???int?a?=?pq.poll();//将当前的第一级优先的值暂存下来,等第二级优先的值取出后再将其加入 ???pq.poll(); ???pq.add(a); ???System.out.println("队列剩余"+Arrays.toString(pq.toArray())); ??} ??System.out.println("取出了"+pq.poll()+",队列剩余"+Arrays.toString(pq.toArray()));? ?}打印效果: 取出了2,队列剩余[3, 4, 5] 3真不是我想要的,我可以接着往下处理么?ok,将3先保留吧 队列剩余[3, 5] 取出了3,队列剩余[5] ? 我觉得这个是优先队列,虽然poll时候会将优先级高的数据先取出,但是同样的,如果加进去是高优先级的数据 下次取的时候它依然还是高优先级的数据。

  • priorityqueuejava 优先队列(priority queue)中,提取第二优先级的值并删除,但是不删除第一优先值的数,怎么实现?相关文档

妮妮云(43元/月 ) 香港 8核8G 43元/月 美国 8核8G

妮妮云的来历妮妮云是 789 陈总 张总 三方共同投资建立的网站 本着“良心 便宜 稳定”的初衷 为小白用户避免被坑妮妮云的市场定位妮妮云主要代理市场稳定速度的云服务器产品,避免新手购买云服务器的时候众多商家不知道如何选择,妮妮云就帮你选择好了产品,无需承担购买风险,不用担心出现被跑路 被诈骗的情况。妮妮云的售后保证妮妮云退款 通过于合作商的友好协商,云服务器提供2天内全额退款,超过2天不退款 物...

Sharktech10Gbps带宽,不限制流量,自带5个IPv4,100G防御

Sharktech荷兰10G带宽的独立服务器月付319美元起,10Gbps共享带宽,不限制流量,自带5个IPv4,免费60Gbps的 DDoS防御,可加到100G防御。CPU内存HDD价格购买地址E3-1270v216G2T$319/月链接E3-1270v516G2T$329/月链接2*E5-2670v232G2T$389/月链接2*E5-2678v364G2T$409/月链接这里我们需要注意,默...

TMThosting夏季促销:VPS月付7折,年付65折,独立服务器95折,西雅图机房

TMThosting发布了一个2021 Summer Sale活动,针对西雅图VPS主机提供月付7折优惠码,年付65折优惠码,独立服务器提供95折优惠码,本轮促销活动到7月25日。这是一家成立于2018年的国外主机商,主要提供VPS和独立服务器租用业务,数据中心包括美国西雅图和达拉斯,其中VPS基于KVM架构,都有提供免费的DDoS保护,支持选择Windows或者Linux操作系统。Budget ...

priorityqueue为你推荐
素数算法什么是素数算法ico监管BTCB是什么?代发邮件什么是商务邮件代发?qq管家官网在qq电脑管家官网有个可以登录qq的。登录上了可以加速么?gas是什么意思GC什么意思动画分镜头脚本求份《仙剑奇侠传5》剧情动画分镜头脚本 越多越好ocr软件下载哪个图片转文字软件比较好用?pass是什么锒行卡上的闪付pass是什么意思?asp论坛源码ASP论坛源代码为什么上传到ASP空间后打不开data什么意思c语言 data的作用
域名服务器是什么 域名解析服务器 新网域名管理 ion 密码泄露 512m内存 国内加速器 免费ftp站点 网站挂马检测工具 三拼域名 卡巴斯基官方免费版 nerds vip域名 新世界服务器 万网主机管理 移动服务器托管 便宜空间 789 大化网 重庆服务器 更多