It is said that in 2013, there were about 100 graduate schools ready to proceed over 40,000 applications in Zhejiang Province.  It would help a lot if you could write a program to automate the admission procedure.

Each applicant will have to provide two grades: the national entrance exam grade GE, and the interview grade GI.  The final grade of an applicant is (GE + GI) / 2.  The admission rules are:

  • The applicants are ranked according to their final grades, and will be admitted one by one from the top of the rank list.
  • If there is a tied final grade, the applicants will be ranked according to their national entrance exam grade GE.  If still tied, their ranks must be the same.
  • Each applicant may have K choices and the admission will be done according to his/her choices: if according to the rank list, it is one's turn to be admitted; and if the quota of one's most preferred shcool is not exceeded, then one will be admitted to this school, or one's other choices will be considered one by one in order. If one gets rejected by all of preferred schools, then this unfortunate applicant will be rejected.
  • If there is a tied rank, and if the corresponding applicants are applying to the same school, then that school must admit all the applicants with the same rank, even if its quota will be exceeded.

Input Specification:

Each input file contains one test case.  Each case starts with a line containing three positive integers: N (<=40,000), the total number of applicants; M (<=100), the total number of graduate schools; and K (<=5), the number of choices an applicant may have.

In the next line, separated by a space, there are M positive integers.  The i-th integer is the quota of the i-th graduate school respectively.

Then N lines follow, each contains 2+K integers separated by a space.  The first 2 integers are the applicant's GE and GI, respectively.  The next K integers represent the preferred schools.  For the sake of simplicity, we assume that the schools are numbered from 0 to M-1, and the applicants are numbered from 0 to N-1.

Output Specification:

For each test case you should output the admission results for all the graduate schools.  The results of each school must occupy a line, which contains the applicants' numbers that school admits.  The numbers must be in increasing order and be separated by a space.  There must be no extra space at the end of each line.  If no applicant is admitted by a school, you must output an empty line correspondingly.

Sample Input:

11 6 3
2 1 2 2 2 3
100 100 0 1 2
60 60 2 3 5
100 90 0 3 4
90 100 1 2 0
90 90 5 1 3
80 90 1 0 2
80 80 0 1 2
80 80 0 1 2
80 70 1 3 2
70 80 1 2 3
100 100 0 2 4

Sample Output:

0 10
3
5 6 7
2 8 1 4
// 1080pat.cpp : 定义控制台应用程序的入口点。
//
#include <iostream>
#include <vector>
#include <algorithm>
#include <functional>
using namespace std; const int schools=; //最多的研究生院个数
vector<int> quota; //每个研究生院的限额 struct App
{
int num; //申请人编号,从0开始
int GE;
int GI;
int Final;
int rank; //申请人的排名
int choices[];
bool operator <(const App& rhs) const
{
if(Final==rhs.Final)
{
return GE>rhs.GE;
}
else
return Final>rhs.Final;
}
}; class T:public unary_function<App,bool> //for_each处理,得到每个申请人的相对排名
{
public:
T(App& aa):app(aa){}
bool operator()(App& a)
{
if(a.Final<app.Final)
{
a.rank=app.rank+;
}
else
{
if(a.GE<app.GE)
{
a.rank=app.rank+;
}
else
a.rank=app.rank;
}
app=a;
return true;
}
private:
App app;
};
vector<App> applicants; //所有的申请人
vector<int> res[schools]; //每个研究生院录取的申请人编号
int sranks[schools]; //每个研究生院录取的申请人的当前最新排名,用来处理case4 int main()
{
int N,M,K; //数据输入
cin>>N>>M>>K;
int qbuf;
int i;
for(i=;i<M;++i)
{
cin>>qbuf;
quota.push_back(qbuf);
}
for(i=;i<N;++i)
{
App Abuf; //每次定义一个,如果定义到外面的话,在App中要重载operator=
cin>>Abuf.GE>>Abuf.GI;
Abuf.Final=(Abuf.GE+Abuf.GI)>>;
for(int j=;j<K;++j)
{
cin>>Abuf.choices[j];
}
Abuf.num=i;
applicants.push_back(Abuf);
}
sort(applicants.begin(),applicants.end()); //排序
applicants[].rank=;
for_each(applicants.begin(),applicants.end(),T(applicants[])); //得到相对排名
for(vector<App>::iterator iter=applicants.begin();iter!=applicants.end();++iter)
{
for(int j=;j<K;++j)
{
//每个申请人的申请的第j个研究生院还有名额,或者跟之前录取的有相同的排名
if(quota[iter->choices[j]]>||sranks[iter->choices[j]]==iter->rank)
{
--quota[iter->choices[j]]; //研究生院的名额减少一个
res[iter->choices[j]].push_back(iter->num);//将录取的申请人添加到对应的研究生院
sranks[iter->choices[j]]=iter->rank; //更新对应研究生院的最新录取申请人的排名
break;
}
}
}
for(i=;i<M;++i)
{
int size=res[i].size();
if(==size)
cout<<endl;
else
{
sort(res[i].begin(),res[i].end());
for(int j=;j<size;++j)
{
if(!=j)
cout<<" ";
cout<<res[i][j];
}
cout<<endl;
}
}
return ;
}
编译器
C (gcc)
C# (mcs)
C++ (g++)
Go (gccgo)
Haskell (ghc)
Java (gcj)
Javascript (nodejs)
Lisp (clisp)
Lua (lua)
Pascal (fpc)
PHP (php)
Python (python3)
Python (python2)
Ruby (ruby)
Scheme (guile)
Shell (bash)
Vala (valac)
VisualBasic (vbnc)
  
         使用高级编辑器    

代码

 
 
1
 
 
  

PAT 1080. Graduate Admission (30)的更多相关文章

  1. pat 甲级 1080. Graduate Admission (30)

    1080. Graduate Admission (30) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue It ...

  2. PAT 甲级 1080 Graduate Admission (30 分) (简单,结构体排序模拟)

    1080 Graduate Admission (30 分)   It is said that in 2011, there are about 100 graduate schools ready ...

  3. PAT 1080 Graduate Admission[排序][难]

    1080 Graduate Admission(30 分) It is said that in 2011, there are about 100 graduate schools ready to ...

  4. PAT (Advanced Level) 1080. Graduate Admission (30)

    简单题. #include<cstdio> #include<cstring> #include<cmath> #include<vector> #in ...

  5. 【PAT甲级】1080 Graduate Admission (30 分)

    题意: 输入三个正整数N,M,K(N<=40000,M<=100,K<=5)分别表示学生人数,可供报考学校总数,学生可填志愿总数.接着输入一行M个正整数表示从0到M-1每所学校招生人 ...

  6. 1080. Graduate Admission (30)

    时间限制 200 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue It is said that in 2013, there w ...

  7. 1080 Graduate Admission (30)(30 分)

    It is said that in 2013, there were about 100 graduate schools ready to proceed over 40,000 applicat ...

  8. PAT 1080. Graduate Admission

    It is said that in 2013, there were about 100 graduate schools ready to proceed over 40,000 applicat ...

  9. 1080. Graduate Admission (30)-排序

    先对学生们进行排序,并且求出对应排名. 对于每一个学生,按照志愿的顺序: 1.如果学校名额没满,那么便被该学校录取,并且另vis[s][app[i].ranks]=1,表示学校s录取了该排名位置的学生 ...

随机推荐

  1. python 中对list做减法操作

    问题描述:假设我有这样两个list,          一个是list1,list1 = [1, 2, 3, 4, 5]          一个是list2,list2 = [1, 4, 5]     ...

  2. Mvc 分页栏扩展方法

    using System; using System.Collections.Generic; using System.Reflection; using System.Text; using Sy ...

  3. caffe之(二)pooling层

    在caffe中,网络的结构由prototxt文件中给出,由一些列的Layer(层)组成,常用的层如:数据加载层.卷积操作层.pooling层.非线性变换层.内积运算层.归一化层.损失计算层等:本篇主要 ...

  4. JavaWeb学习总结(一)——JavaWeb开发入门(转载)

    转载自http://www.cnblogs.com/xdp-gacl/p/3729033.html感谢孤傲苍狼的分享. 一.基本概念 1.1.WEB开发的相关知识 WEB,在英语中web即表示网页的意 ...

  5. Linux用户环境变量

    Linux用户环境变量 环境变量就是系统或软件设置的一些参数,用户环境变量就是用户登录系统后,都有自已专用的运行环境.在Windows系统中用户环境变量保存在用户家目录,Linux也是同样的.本文主要 ...

  6. Wild Words

    poj1816:http://poj.org/problem?id=1816 题意:给你n个模板串,然后每个串除了字母,还有?或者*,?可以代替任何非空单个字符,*可以替代任何长度任何串,包括空字符串 ...

  7. 【网络流24题】No. 20 深海机器人问题 (费用流)

    [题意] 深海资源考察探险队的潜艇将到达深海的海底进行科学考察.潜艇内有多个深海机器人. 潜艇到达深海海底后, 深海机器人将离开潜艇向预定目标移动. 深海机器人在移动中还必须沿途采集海底生物标本. 沿 ...

  8. 【UVA 10816】 Travel in Desert (最小瓶颈树+最短路)

    [题意] 有n个绿洲, m条道路,每条路上有一个温度,和一个路程长度,从绿洲s到绿洲t,求一条道路的最高温度尽量小, 如果有多条, 选一条总路程最短的. InputInput consists of ...

  9. vlc

    源码下载地址:http://download.videolan.org/pub/videolan/vlc/ 编译依赖: sudo apt-get install liblua5.2-dev sudo ...

  10. ColorFilter类

    以前没用到过LightingColorFilter这个类 ,google了下 @Override protected void onDraw(Canvas canvas) { int mul = 0x ...