11733274 2014-09-26 12:42:31 Accepted 5040 62MS 1592K 4848 B G++ czy

 

先转一个优先队列的用法:

http://www.cppblog.com/shyli/archive/2007/04/06/21366.html

优先队列用法

在优先队列中,优先级高的元素先出队列。 标准库默认使用元素类型的<操作符来确定它们之间的优先级关系。 优先队列的第一种用法,也是最常用的用法:

hdu 5040 Instrusive【BFS+优先队列】priority_queue<int> qi;

通过<操作符可知在整数中元素大的优先级高。 故示例1中输出结果为:9 6 5 3 2
第二种方法: 在示例1中,如果我们要把元素从小到大输出怎么办呢? 这时我们可以传入一个比较函数,使用functional.h函数对象作为比较函数。

hdu 5040 Instrusive【BFS+优先队列】priority_queue<int, vector<int>, greater<int> >qi2;

其中 第二个参数为容器类型。 第二个参数为比较函数。 故示例2中输出结果为:2 3 5 6 9
第三种方法: 自定义优先级。

hdu 5040 Instrusive【BFS+优先队列】struct node hdu 5040 Instrusive【BFS+优先队列】{ hdu 5040 Instrusive【BFS+优先队列】    friend bool operator< (node n1, node n2) hdu 5040 Instrusive【BFS+优先队列】    { hdu 5040 Instrusive【BFS+优先队列】        return n1.priority < n2.priority; hdu 5040 Instrusive【BFS+优先队列】    } hdu 5040 Instrusive【BFS+优先队列】    int priority; hdu 5040 Instrusive【BFS+优先队列】    int value; hdu 5040 Instrusive【BFS+优先队列】};

在该结构中,value为值,priority为优先级。 通过自定义operator<操作符来比较元素中的优先级。 在示例3中输出结果为: 优先级  值 9          5 8          2 6          1 2          3 1          4 但如果结构定义如下:

hdu 5040 Instrusive【BFS+优先队列】struct node hdu 5040 Instrusive【BFS+优先队列】{ hdu 5040 Instrusive【BFS+优先队列】    friend bool operator> (node n1, node n2) hdu 5040 Instrusive【BFS+优先队列】    { hdu 5040 Instrusive【BFS+优先队列】        return n1.priority > n2.priority; hdu 5040 Instrusive【BFS+优先队列】    } hdu 5040 Instrusive【BFS+优先队列】    int priority; hdu 5040 Instrusive【BFS+优先队列】    int value; hdu 5040 Instrusive【BFS+优先队列】};

则会编译不过(G++编译器) 因为标准库默认使用元素类型的<操作符来确定它们之间的优先级关系。 而且自定义类型的<操作符与>操作符并无直接联系,故会编译不过。
//代码清单

hdu 5040 Instrusive【BFS+优先队列】#include<iostream> hdu 5040 Instrusive【BFS+优先队列】#include<functional> hdu 5040 Instrusive【BFS+优先队列】#include<queue> <<

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2022-01-07
  • 2021-11-09
  • 2022-12-23
  • 2021-08-21
  • 2022-12-23
  • 2021-09-07
猜你喜欢
  • 2022-12-23
  • 2021-12-26
  • 2021-11-16
  • 2021-05-28
  • 2021-10-06
  • 2021-10-03
  • 2022-12-23
相关资源
相似解决方案