poj 2823 参考的优先队列

poj 2823

感觉没什么大区别,怎么就RE呢??????

#include<algorithm> 
#include<queue> 
#include<vector> 
using namespace std; 
int a[1000011];//数组数据 

int OutMin[1000011];//最小值 

int OutMax[1000011];//最大值 

int cnt1=0; 
int cnt2=0; 
int n,k; 

struct cmp1 
{ 
    bool operator()(const int a1,const int a2) 
    { 
        return a[a1]>a[a2]; 
    } 
}; 
struct cmp2 
{ 
    bool operator()(const int a1,const int a2) 
    { 
        return a[a1]<a[a2]; 
    } 
}; 
priority_queue <int ,vector<int>,cmp1> Q1; 
priority_queue <int ,vector<int>,cmp2> Q2; 
int main() 
{ 
    int i; 
    scanf("%d%d",&n,&k); 
    if(k>n) 
        k=n; 
    for(i=1;i<=n;++i) 
    { 
        scanf("%d",&a[i]); 
    } 

    for(i=1;i<=k;++i) 
    { 
        Q1.push(i); 
        Q2.push(i); 
    } 


    OutMin[cnt1++]=a[Q1.top()]; 
    OutMax[cnt2++]=a[Q2.top()]; 
    for(i=k+1;i<=n;++i) 
    { 
        Q1.push(i); 
        Q2.push(i); 
        while(i-Q1.top()>=k) 
            Q1.pop(); 
        OutMin[cnt1++]=a[Q1.top()]; 
        while(i-Q2.top()>=k) 
            Q2.pop(); 
        OutMax[cnt2++]=a[Q2.top()]; 
    } 
	
    for(i=0;i<=(n-k);++i) 
    { 
        printf("%d%c", OutMin[i], (i < n - k) ? ' ' : '\n');  
		
    } 
    for(i=0;i<=(n-k);++i) 
    { 
        printf("%d%c", OutMax[i], (i < n - k) ? ' ' : '\n');  
    } 
    return 0; 
}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值