考试晋级(排序)

题目描述

有n个人参加了期末考试,为了检测大家真正的学习成绩老师决定对于成绩好的同学进行第二轮测试,当然不是每个人都有进入第二轮的机会,这里有个根据期末考试分数制定的晋级规则:
1)分数高的优先晋级
2)至多只能允许k个人晋级下一轮
3)为了保证公平分数相同的人要么一起晋级要么一起出局
老师最近很忙不知道最终到底有多少人可以晋级下一轮而且晋级的最低分数是多少.作为优秀的程序员这个任务当然就交给你来完成了!
输入

首先输入一个T表示T组测试数据
然后输入俩个n,k表示有n个人,最多允许k个人晋级
然后是一行n个数表示n个人的成绩
输出

对于每组测试数组,首先输出"Case #X: ",X代表测试用例的编号(具体可参见sample output), 然后输出两个整数sum, min,表示可以晋级多少人和最低的晋级分数.如果无人能晋级则输出两个-1。
样例输入

3
1 1
5
10 7
1 2 3 4 5 6 7 8 9 10
10 2
1 1 2 3 3 4 4 5 5 5
样例输出

Case #1: 1 5
Case #2: 7 4
Case #3: -1 -1
---------------------------分割线-------------------------------
个人思路:
1:排序,直接套用sort或许可行;
2:注意-1情况,先判断人数再继续输出;
代码:

#include
#include
#include
#include
#include
#include
#include
using namespace std;
int main()
{
    int t;
    const int maxn=10007;//方便修改
    int men[maxn];//定义排序数组
    while(cin>>t)
    {
        for(int p=0;p>n>>k;
            for(int i=0;i>men[i];
            sort(men,men+n);//自动从小到大排序
            int minp=men[n-1]+1;//比最大大1,嘻嘻(其实没必要)
            int sum=0;
            while(sumk)
                    break;//超标自然不算数
                sum+=o;
                minp=men[n-sum];
            }
            if(!sum)//sum为0无人生还
                cout<<"Case #"<

你可能感兴趣的:(考试晋级(排序))