c ++ stl优先级队列构造函数

Avi*_*mar 1 c++ stl priority-queue

我编写了以下代码来接受许多输入,然后按特定顺序输出它们.

#DEFINE cases 100     

struct job
{
int w;
};

class compjob
{
public:
       bool operator()( job j1,job j2)
       {
       if(j2.w>j1.w)
       return true;

       return false;
       }
};

int main()
{
priority_queue< job, vector<job>, compjob > jobs;

int weight;



for(int i=1;i<=cases;i++)
{
cin>>weight;
job job1;
job1.w=weight;

jobs.push(job1);
} //for loop ends here


for(int i=1;i<=cases;i++)
{
job job1= jobs.pop(); ////////////ERROR!!!!!/////////
cout<<job1.w<<endl;
}

return 0;;
}
Run Code Online (Sandbox Code Playgroud)

但是当我编译代码时,在上面标记的行上显示编译错误:

Invalid conversion from 'void' to non scalar 'job'.
Run Code Online (Sandbox Code Playgroud)

我认为我没有正确地声明作业priority_queue.另外,请解释声明中第二个参数的意义(即矢量,我真的不知道它的用途)

Ash*_*sha 7

pop不返回任何内容,首先使用top来获取元素然后弹出它.