C++的priority_queue实现最大堆
2013-04-10 16:00
405 查看
最大堆在面试题和笔试题中常常见到,练习一下吧,总没有坏处...
#include<stdio.h>
#include<queue>
using namespace std;
const int k = 10;
struct node
{
int n;
int weight;
};
typedef struct node Node;
//以权重weight的值建立最大堆
struct cmp
{
bool operator()(const Node &a,const Node &b)
{
return a.weight < b.weight;
}
};
priority_queue<Node, vector<Node>, cmp> priorityQueue;
void initQueue()
{
for(int i=0; i<15; i++)
{
Node node;
scanf("%d %d", &node.n, &node.weight);
priorityQueue.push(node);
}
//Node n = priorityQueue.top();
//printf("%d %d\n", n.n, n.weight);
}
//取出k个元素
void getMembers(int k)
{
while(k--)
{
Node node = priorityQueue.top();
priorityQueue.pop();
printf("%d %d\n", node.n, node.weight);
}
}
int main()
{
initQueue();
getMembers(10);
return 0;
}
#include<stdio.h>
#include<queue>
using namespace std;
const int k = 10;
struct node
{
int n;
int weight;
};
typedef struct node Node;
//以权重weight的值建立最大堆
struct cmp
{
bool operator()(const Node &a,const Node &b)
{
return a.weight < b.weight;
}
};
priority_queue<Node, vector<Node>, cmp> priorityQueue;
void initQueue()
{
for(int i=0; i<15; i++)
{
Node node;
scanf("%d %d", &node.n, &node.weight);
priorityQueue.push(node);
}
//Node n = priorityQueue.top();
//printf("%d %d\n", n.n, n.weight);
}
//取出k个元素
void getMembers(int k)
{
while(k--)
{
Node node = priorityQueue.top();
priorityQueue.pop();
printf("%d %d\n", node.n, node.weight);
}
}
int main()
{
initQueue();
getMembers(10);
return 0;
}
相关文章推荐
- C++最大堆实现priority_queue优先级队列(算法导论)
- 【C++ STL应用与实现】13: 如何使用std::queue和std::priority_queue
- c++/java/python priority_que实现最大堆和最小堆
- C++ priority_queue 最大堆、最小堆
- 用multiset/priority_Queue来实现最大最小堆
- 用C++ std::priority_queue 实现哈夫曼算法
- C++ priority_queue(优先队列)使用
- 求两个整数的最小公倍数和最大公约数的算法及其C++实现
- 利用priority_queue实现top K
- C++ STL入门教程(4)——stack,queue,priority_queue的使用(附完整程序代码)
- 队列(queue)的链表(list)实现及循环数组(circular array)实现 C++实现
- priority_queue实现
- c++实现最大堆建立(链表结构)和堆排序
- 算法设计与分析--求最大子段和问题(蛮力法、分治法、动态规划法) C++实现
- 队列(queue)的链表(list)实现及循环数组(circular array)实现 C++实现
- 最大子数组问题-c++代码实现及运行实例结果
- 关于c++优先队列priority_queue的几点浅显认识
- c++ 队列Queue的实现 - 练习题
- C++重载运算符 < priority_queue 相关(个人笔记)
- 【数据结构与算法基础】优先队列(二叉堆实现) / Priority Queue implemented by binary heap