备战蓝桥杯---数据结构与STL应用(入门1)

话不多说,直接看题:

下面为分析:显然,我们要先合并最小的两堆(因为他们在后边也得被计算,换句话,我们独立的看,某一堆的体力值为他自己重量*从现在到最后的次数)

因此,我们可以用两个队列来做。下面我用图来描述过程:(其实可以直接优先队列)

下面为AC代码:

接题(比较难):

这个题跟上一个有异曲同工之妙,我们可以用3个队列来维护最大长度(用优先队列会超),同时,有个十分巧妙地点,对于某个过程产生的蚯蚓,我们让他们-前面时间增加的长度,这样统一了基准,巧妙地把某个过程产生的蚯蚓化为一开始就产生的。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
#define int long long
int n,m,q,u,v,t,a[100010],ck;
bool cmp(int a,int b){
    return a>b;
}
signed main(){
    scanf("%d%d%d%d%d%d",&n,&m,&q,&u,&v,&t);
    for(int i=1;i<=n;i++){
        scanf("%d",&a[i]);
    }
    sort(a+1,a+n+1,cmp);
    queue<int> q1;
    queue<int> q2;
    queue<int> q3;
    for(int i=1;i<=n;i++){
        q1.push(a[i]);
    }
    for(int i=1;i<=m;i++){
        int max1,a1=-0x7f7f7f7f,a2=-0x7f7f7f7f,a3=-0x7f7f7f7f;
        if(!q1.empty()) a1=q1.front();
        if(!q2.empty()) a2=q2.front();
        if(!q3.empty()) a3=q3.front();
        max1=max(a1,max(a2,a3));
        if(max1==a1) q1.pop();
        else if(max1==a2) q2.pop();
        else q3.pop();
        max1+=(i-1)*q;
        if(i%t==0) cout<<max1<<" ";
        q2.push(max1*u/v-(i)*q);
        q3.push(max1-max1*u/v-(i)*q); 
    }
    cout<<endl;
    while(!q1.empty()&&!q2.empty()&&!q3.empty()){
        int a1=q1.front(),a2=q2.front(),a3=q3.front();
        if(a1>=max(a2,a3)){
            q1.pop();
            ck++;
            if(ck%t==0) cout<<a1+q*m<<" ";
            continue;
        }
        if(a2>=max(a1,a3)){
            q2.pop();
            ck++;
            if(ck%t==0) cout<<a2+q*m<<" ";
            continue;
        }
        if(a3>=max(a2,a1)){
            q3.pop();
            ck++;
            if(ck%t==0) cout<<a3+q*m<<" ";
            continue;
        }
    }
    if(q1.empty()){
        while(!q2.empty()&&!q3.empty()){
            if(q2.front()>q3.front()){
                ck++;
                if(ck%t==0)cout<<q2.front()+q*m<<" ";
                q2.pop();
            }
            else{ck++;
                if(ck%t==0)cout<<q3.front()+q*m<<" ";
                q3.pop();
            }
        }
        while(!q2.empty()&&q3.empty()){
            ck++;
            if(ck%t==0)cout<<q2.front()+q*m<<" ";
            q2.pop();
        }
        while(!q3.empty()&&q2.empty()){
            ck++;
           if(ck%t==0) cout<<q3.front()+q*m<<" ";
            q3.pop();
        }
        return 0;
    }
     if(q2.empty()){
        while(!q1.empty()&&!q3.empty()){
            if(q1.front()>q3.front()){
                ck++;
               if(ck%t==0) cout<<q1.front()+q*m<<" ";
                q1.pop();
            }
            else{ck++;
            if(ck%t==0) cout<<q3.front()+q*m<<" ";
                q3.pop();
            }
        }
        while(!q1.empty()&&q3.empty()){
            ck++;
           if(ck%t==0) cout<<q1.front()+q*m<<" ";
            q1.pop();
        }
        while(!q3.empty()&&q1.empty()){
            ck++;
           if(ck%t==0) cout<<q3.front()+q*m<<" ";
            q3.pop();
        }
        return 0;
    }
     if(q3.empty()){
        while(!q2.empty()&&!q1.empty()){
            if(q2.front()>q1.front()){
                ck++;
               if(ck%t==0) cout<<q2.front()+q*m<<" ";
                q2.pop();
            }
            else{ck++;
               if(ck%t==0) cout<<q1.front()+q*m<<" ";
                q1.pop();
            }
        }
        while(!q2.empty()&&q1.empty()){
            ck++;
           if(ck%t==0) cout<<q2.front()+q*m<<" ";
            q2.pop();
        }
        while(!q1.empty()&&q2.empty()){
            ck++;
          if(ck%t==0) cout<<q1.front()+q*m<<" ";
            q1.pop();
        }
    }
}
相关推荐
王老师青少年编程6 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮7 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
样例过了就是过了8 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
谭欣辰9 小时前
C++ 排列组合完整指南
开发语言·c++·算法
橙子也要努力变强9 小时前
信号捕捉底层机制-机理篇2
linux·服务器·c++
盐焗鹌鹑蛋10 小时前
【C++】stack和queue类
c++
MegaDataFlowers10 小时前
206.反转链表
数据结构·链表
郝学胜-神的一滴11 小时前
罗德里格斯旋转公式(Rodrigues‘ Rotation Formula)完整推导
c++·unity·godot·图形渲染·three.js·unreal
lzh2004091911 小时前
深入理解进程:从PCB内核结构到写时拷贝的底层实战
linux·c++
aseity11 小时前
跨平台项目中QString 与 非Qt 跨平台动态库在字符集上的一个实用的互操作约定.
c++·经验分享