1080 Graduate Admission

#include <iostream>
#include <string.h>
#include <algorithm>
#include <cstdio>
using namespace std;
struct student {
	int id;
	int GE;
	int GI;
	int avl;
	int choices[10];
	int Rank;
}stu[100010];
struct school{
	int students[100];
	int num;
}sch[110];
bool cmp(student a,student b)
{
	if(a.avl!=b.avl) return a.avl>b.avl;
	else if(a.GE!=b.GE) return a.GE>b.GE;
}
bool cmp1(int a,int b)
{
	if(a!=b) return a<b;
}
int main()
{
	freopen("C:\\Users\\KEKE\\Desktop\\test.txt","r",stdin);
	for(int i=0;i<100010;i++)
	{
		stu[i].avl=0;
	}
	int n,m,k;
	scanf("%d%d%d",&n,&m,&k);
	int s[100];
	for(int i=0;i<m;i++)
	{
		scanf("%d",&s[i]);
	}
	for(int i=0;i<n;i++)
	{
		stu[i].id=i;
		scanf("%d %d",&stu[i].GE,&stu[i].GI);
		stu[i].avl=stu[i].GE+stu[i].GI;
		for(int j=0;j<k;j++)
		{
			scanf("%d",&stu[i].choices[j]);
		}
	}
	for(int i=0;i<m;i++)
	{
		sch[i].num=0;
	}
	sort(stu,stu+n,cmp);
	stu[0].Rank=1;
	for(int i=1;i<n;i++)
	{
		if(stu[i].avl<stu[i-1].avl)
		{
			stu[i].Rank=i+1;
		}
		else if(stu[i].avl==stu[i-1].avl)
		{
			if(stu[i].GE<stu[i-1].GE)
				stu[i].Rank=i+1;
			else
				stu[i].Rank=stu[i-1].Rank;
		}
	}
	for(int i=0;i<n;i++)
	{
		for(int j=0;j<k;j++)
		{
			int schild=stu[i].choices[j];//当前学生的志愿学校
			if(sch[schild].num<s[schild]||(stu[i].Rank==stu[sch[schild].students[sch[schild].num-1]].Rank))//学校没满
			{
				sch[schild].students[sch[schild].num]=stu[i].id;
				sch[schild].num++;
				break;
			}
		}
	}
	for(int i=0;i<m;i++)
	{
		if(sch[i].num==0)
		{
			printf("\n");
		}
		else
		{
			sort(sch[i].students,sch[i].students+sch[i].num,cmp1);
			printf("%d",sch[i].students[0]);
			for(int j=1;j<sch[i].num;j++)
			{
				printf(" %d",sch[i].students[j]);
			}
			printf("\n");
		}
		
	}
}
上一篇:数据结构 第五章 树-特殊二叉树


下一篇:AVL平衡二叉树模板(C++版)