| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 463 人关注过本帖
标题:关于优先队列的问题
只看楼主 加入收藏
宅宅
Rank: 1
等 级:新手上路
帖 子:27
专家分:9
注 册:2013-9-25
结帖率:92.86%
收藏
已结贴  问题点数:10 回复次数:4 
关于优先队列的问题
优先队列里存结构 struct{int x,y,z;}
我想根据Z的大小决定优先度,怎么实现?

还有,如果队列里存的数组下标,能根据数组下标对应值的大小决定优先度吗?
2014-02-13 11:23
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:0 
据Z的大小决定优先度?? 什么优先度。队列没有优先度这个说法吧,你是否想说排序?
如果是,在插入时候做下处理,放到指定的位置不就行了?

第二个问题 不知道你问什么

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2014-02-13 12:00
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:0 
是指 std::priority_queue 吗?若是,看其模板第三个参数。
2014-02-13 16:05
宅宅
Rank: 1
等 级:新手上路
帖 子:27
专家分:9
注 册:2013-9-25
收藏
得分:0 
回复 3楼 rjsp
就是不知道这个参数怎么用。。。
2014-02-14 11:48
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:10 
回复 4楼 宅宅
程序代码:
#include <queue>
#include <iostream>
using namespace std;

struct foo
{
    int x, y, z;

    foo( int x, int y, int z ) : x(x), y(y), z(z)
    {
    }
};

struct foo_comp_z
{
    bool operator()( const foo& lhs, const foo& rhs ) const
    {
        return lhs.z < rhs.z;
    }
};

int main( void )
{
    std::priority_queue<foo,std::vector<foo>,foo_comp_z> q;
    q.push( foo(0,0,2) );
    q.push( foo(0,0,1) );
    q.push( foo(0,0,3) );

    for( ; !q.empty(); q.pop() )
        cout << q.top().z << endl;

    return 0;
}

2014-02-14 12:13
快速回复:关于优先队列的问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.021619 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved