题解 | #淘汰分数#

淘汰分数

http://www.nowcoder.com/questionTerminal/9c4a4e879b4f49939dfaebea8948f976

主要是要考虑重复分数的情况,主要思路:排序后,依次遍历各个分数

#include <algorithm>
#include <vector>
  
 using namespace std;

void scoreBoundry() {
    int n, x, y;
    cin >> n >> x >> y;
    vector<int> scores(n);
    for (int i = 0; i < n; i++) {
        cin >> scores[i];
    }

    if (x > y || 2 * x > n || 2 * y < n) {
        cout << -1 << endl;
        exit(0);
    }

    sort(scores.begin(), scores.end());
    int i = 0;  
  // 前i个未通过,剩下未n-i个通过, i既代表前i个元素,也代表前i个元素的下一个索引位置        
    while (i < n) { 
   // 二分查找到scores[i]的起始索引范围[i, next), next为下个元素即scores[i+1]的起点位置
        int next = upper_bound(scores.begin() + i, scores.end(), scores[i])  - scores.begin();
        
        if (x <= next && next <= y && x <= n - next && n - next <= y) {     // 首次满足条件,输出最小的m值,并结束
            cout << scores[i]  << endl;
            exit(0);
        }

        if (next > y || n - next < x) {       // i往后遍历,再也不会得到结果,结束
            cout << -1 << endl;
            exit(0);
        }
        i = next;
    }
    cout << -1 << endl;        
}

int main() {

    scoreBoundry();

    return 0;
}
全部评论

相关推荐

机械打工仔:不管啥专业,找工作改简历的第一课先把你那排版改了,简历上不要写个人简历四个字,找你要简历的谁不知道这个是简历?而且还占那么多空间,直接把自己名字和基础信息写上面,整体字体大一些。 还有这种经典两页简历一页大空白,导出PDF的时候多了一页几乎全是白的你自己看着不难受吗随手的事为啥不能改掉呢,这是态度问题,你试想一下你是HR你打开简历看到格式都没调整过会是什么感受?你自己都不重视你的简历,HR更不会在意。 然后内容你那个做两年咖啡就别往里写了,简历在精不在多,你在往你的简历里打字的时候就要想好这东西对你要找的工作有没有帮助。自我评价写一行就行了,不如给专业技能单开一栏。核心课程均分90这个真别写了,把你上过的有用的专业课列出来也行。有很多地方废话很多的精炼一下,比如你校内项目第一个写的那些,全然没有重点。 好好修改一下,我看你内容也挺优秀的,别被一个随便做的简历耽误了,我一个同专业的打工人看了都揪心更别说一天看几百份简历的HR
听劝,我这个简历该怎么改...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务