c++,优先队列

#include <iostream>

#include <algorithm>

#include <cmath>

#include <cstring>

#include <time.h>

using namespace std;

#define ROOT 1

#define FATHER(i) ((i)/2)

#define LEFT(i) ((i)*2)

#define RIGHT(i) ((i)*2+1)

#define cmp >

typedef struct PriorityQueue{

int *__data,*data;

int size,n;

}PriorityQueue;

PriorityQueue *initPQ(int size){

PriorityQueue *p=(PriorityQueue*)malloc(sizeof(PriorityQueue));

p->__data=(int*)malloc(sizeof(int)*size);

p->data=p->__data-ROOT;

p->size=size;

p->n=0;

return p;

}

void clearPQ(PriorityQueue *p){

if(!p)return ;

free(p->__data);

free(p);

return ;

}

int _empty(PriorityQueue *p){

return p->n==0;

}

int full(PriorityQueue *p){

return p->n==p->size;

}

int top(PriorityQueue *p){

return p->data[ROOT];

}

void up_updata(int *data,int i){

cout<<endl<<"up "<<data[i]<<endl;

if(i==ROOT)return ;

if(data[i] cmp data[FATHER(i)]){

swap(data[i],data[FATHER(i)]);

up_updata(data,FATHER(i));

}

cout<<endl;

return ;

}

void down_updata(int *data,int i,int n){

cout<<endl<<"down "<<data[i]<<endl;

while(LEFT(i)<=n){

int ind=i,l=LEFT(i),r=RIGHT(i);

if(data[l] cmp data[ind])ind=LEFT(i);

if(r<=n&&data[r] cmp data[ind])ind=r;

if(ind==i)break;

swap(data[i],data[ind]);

i=ind;

}

cout<<endl;

return ;

}

int push(PriorityQueue *p,int x){

if(full(p))return 0;

p->n+=1;

p->data[p->n]=x;

up_updata(p->data,p->n);

return 1;

}

int pop(PriorityQueue *p){

if(_empty(p))return 0;

p->data[ROOT]=p->data[p->n];

p->n-=1;

down_updata(p->data,ROOT,p->n);

return 1;

}

void output(PriorityQueue *p){

cout<<"pq: "<<p->n<<" ";

for(int i=1;i<=p->n;i++){

cout<<p->data[i]<<" ";

}

cout<<endl;

return ;

}

int main(){

#define MAX_OP 100

PriorityQueue *p=initPQ(MAX_OP);

int op,x;

while(cin>>op){

if(op==1){

cin>>x;

cout<<x<<" insert:"<<endl;

push(p,x);

output(p);

}else{

cout<<"top"<<top(p)<<endl;

pop(p);

output(p);

}

}

clearPQ(p);

return 0;

}

相关推荐
CoovallyAIHub2 分钟前
SBP-YOLO:面向嵌入式悬架的轻量实时模型,实现减速带与坑洼高精度检测
深度学习·算法·计算机视觉
UnnamedOrange24 分钟前
ROS1 配置代码覆盖率
c++·cmake
沐怡旸26 分钟前
【底层机制】std::unordered_map 扩容机制
c++·面试
沐怡旸26 分钟前
【底层机制】auto 关键字的底层实现机制
c++·面试
CoovallyAIHub34 分钟前
医药、零件、饮料瓶盖……SuperSimpleNet让质检“即插即用”
深度学习·算法·计算机视觉
华溢澄36 分钟前
macOS下基于Qt/C++的OpenGL开发环境的搭建
c++·qt·macos·opengl
dragoooon3437 分钟前
[优选算法专题二滑动窗口——串联所有单词的子串]
数据结构·c++·学习·算法·leetcode·学习方法
刃神太酷啦38 分钟前
C++ 异常处理机制:从基础到实践的全面解析----《Hello C++ Wrold!》(20)--(C/C++)
java·c语言·开发语言·c++·qt·算法·leetcode
CYRUS_STUDIO41 分钟前
OLLVM 移植 LLVM18 踩坑:一步步调试修复控制流平坦化
c语言·c++·llvm
将编程培养成爱好1 小时前
C++ 设计模式《外卖菜单展示》
c++·设计模式