数据结构 优先队列 C语言实现
2017-02-26 19:08
295 查看
优先队列------(二叉堆实现)
我们用heap[MAX_N]来表示数据
给每个节点赋予一个编号(就是数组heap的下标),此时,儿子的编号就满足:
左儿子的编号是自己的编号x2+1
右儿子的编号是自己的编号x2+2
int heap[MAX_N],sz=0;
void push(int x)
{
int i,p;
i=sz;//自己节点的编号
sz++;
while(i>0)
{
p=(i-1)/2;//父亲节点的编号
if(heap[p]<=x)
break;//如果已经没有大小颠倒则退出
heap[i]=heap[p];
i=p;//把父亲节点的数值放下来,而把自己提上去
}
heap[i]=x;
}
int pop(void)
{
int ret,x,i,a,b;
ret=heap[0];//最小值
x=heap[--sz];//要提到根的数值
i=0;
while(i*2+1<sz)//从根开始,向下交换
{
a=i*2+1;//左儿子
b=i*2+2;//右儿子
if(b<sz&&heap[b]<heap[a])//比较左右儿子的大小,选择小的
a=b;
if(heap[a]>=x)
break;//没有大小颠倒,退出
heap[i]=heap[a];//把儿子的数值提上来
i=a;
}
heap[i]=x;
return ret;
}
判断队列是否为空的时候,可以看sc,如果sc>0,则队列不为空,否则就是空
我们用heap[MAX_N]来表示数据
给每个节点赋予一个编号(就是数组heap的下标),此时,儿子的编号就满足:
左儿子的编号是自己的编号x2+1
右儿子的编号是自己的编号x2+2
int heap[MAX_N],sz=0;
void push(int x)
{
int i,p;
i=sz;//自己节点的编号
sz++;
while(i>0)
{
p=(i-1)/2;//父亲节点的编号
if(heap[p]<=x)
break;//如果已经没有大小颠倒则退出
heap[i]=heap[p];
i=p;//把父亲节点的数值放下来,而把自己提上去
}
heap[i]=x;
}
int pop(void)
{
int ret,x,i,a,b;
ret=heap[0];//最小值
x=heap[--sz];//要提到根的数值
i=0;
while(i*2+1<sz)//从根开始,向下交换
{
a=i*2+1;//左儿子
b=i*2+2;//右儿子
if(b<sz&&heap[b]<heap[a])//比较左右儿子的大小,选择小的
a=b;
if(heap[a]>=x)
break;//没有大小颠倒,退出
heap[i]=heap[a];//把儿子的数值提上来
i=a;
}
heap[i]=x;
return ret;
}
判断队列是否为空的时候,可以看sc,如果sc>0,则队列不为空,否则就是空
相关文章推荐
- 优先队列(堆) - C语言实现(摘自数据结构与算法分析 C语言描述)
- 数据结构实现链式队列(C语言)
- C语言 队列的链式结构的实现与表示 数据结构 队列的实现与表示
- 数据结构:循环队列(C语言实现)
- 数据结构C语言实现系列——队列
- 数据结构:队列(C语言实现)
- 数据结构_使用二叉堆实现优先队列
- C语言队列实现广度优先遍历
- 数据结构C语言实现系列——队列
- 数据结构循环队列斐波拉契数列的实现(c语言)
- 数据结构C语言实现之链式队列的6种算法代码
- (C语言)队列的链式实现(数据结构十一)
- 数据结构C语言实现系列——队列
- 数据结构之优先队列--二叉堆(Java实现)
- 数据结构C语言实现—队列操作
- 数据结构 --静态队列的一个简单的C语言代码实现
- (C语言队列的顺序实现(数据结构十)
- (C语言队列的顺序实现(数据结构十)
- 优先队列二叉堆 C语言实现
- 数据结构中栈与队列的c语言代码实现