University Entrace Examination zoj1023
学校招收学生 优先级按照: 分数 是否本地 志愿先后
相当于 女的开后宫
对gs进行略微修改
结束的条件为每个男的表白完所有女的
第二部分比较时 找出女的后宫里的吸引力最弱的男的比较 然后是否取代
- #include<cstdio>
- #include<cstring>
- #include<algorithm>
- #include<cmath>
- #define N 200
- #define eps 1e-6
- using namespace std;
- struct node
- {
- int id,region,score,k;
- }stu[N];
- struct node1
- {
- int region,num;
- }sch[N];
- struct node2
- {
- int cnt;
- int manname[N];
- }woman[N];
- int r,n,m;
- int map1[N][N],map2[N][N],man[N],times[N],vis[N];
- int cmp(node a,node b)
- {
- if(a.region==r)
- {
- if(b.region==r)
- return a.score>b.score;
- if(b.region!=r)
- {
- if(abs(a.score-0.7*b.score)<eps)
- return ;
- else
- return a.score>0.7*b.score;
- }
- }
- else if(b.region==r)
- {
- if(a.region==r)
- return a.score>b.score;
- if(a.region!=r)
- {
- if(abs(b.score-0.7*a.score)<eps)
- return ;
- else
- return b.score<0.7*a.score;
- }
- }
- else
- return a.score>b.score;
- }
- int cmp1(node a,node b)
- {
- return a.id<b.id;
- }
- void makerank()
- {
- int i,j;
- for(i=;i<=m;i++)
- {
- r=sch[i].region;
- sort(stu+,stu+n+,cmp);
- for(j=;j<=n;j++)
- map2[i][stu[j].id]=j;
- }
- sort(stu+,stu+n+,cmp1);
- }
- void Gale_Shapley()
- {
- int flag=,i,j,worstrank,worstrankj;
- memset(man,,sizeof(man));
- for(i=;i<=n;i++)
- times[i]=;
- for(i=;i<=n;i++)
- vis[i]=;
- for(i=;i<=m;i++)
- woman[i].cnt=;
- while(flag)
- {
- flag=;
- for(i=;i<=n;i++)
- {
- while(!man[i]&&!vis[i])
- {
- flag=;
- if(times[i]>stu[i].k)
- {
- vis[i]=;
- break;
- }
- int name=map1[i][times[i]];
- if(woman[name].cnt<sch[name].num)
- {
- woman[name].manname[++woman[name].cnt]=i;
- man[i]=name;
- times[i]++;
- }
- else if(woman[name].cnt==sch[name].num)
- {
- worstrank=;
- for(j=;j<=woman[name].cnt;j++)
- {
- if(map2[name][woman[name].manname[j]]>worstrank)
- {
- worstrank=map2[name][woman[name].manname[j]];
- worstrankj=j;
- }
- }
- if(map2[name][i]<worstrank)
- {
- man[woman[name].manname[worstrankj]]=;
- woman[name].manname[worstrankj]=i;
- man[i]=name;
- times[i]++;
- }
- else
- times[i]++;
- }
- }
- }
- }
- }
- int main()
- {
- int T,j,i;
- scanf("%d",&T);
- while(T--)
- {
- memset(map1,,sizeof(map1));
- memset(map2,,sizeof(map2));
- scanf("%d%d",&n,&m);
- for(i=;i<=n;i++)
- {
- stu[i].id=i;
- scanf("%d%d%d",&stu[i].region,&stu[i].score,&stu[i].k);
- for(j=;j<=stu[i].k;j++)
- {
- scanf("%d",&map1[i][j]);
- }
- }
- for(i=;i<=m;i++)
- {
- scanf("%d%d",&sch[i].region,&sch[i].num);
- }
- makerank();
- Gale_Shapley();
- for(i=;i<=n;i++)
- if(vis[i])
- printf("not accepted\n");
- else
- printf("%d\n",man[i]);
- if(T) printf("\n");
- }
- return ;
- }
University Entrace Examination zoj1023的更多相关文章
- POJ题目细究
acm之pku题目分类 对ACM有兴趣的同学们可以看看 DP: 1011 NTA 简单题 1013 Great Equipment 简单题 102 ...
- 【转】POJ百道水题列表
以下是poj百道水题,新手可以考虑从这里刷起 搜索1002 Fire Net1004 Anagrams by Stack1005 Jugs1008 Gnome Tetravex1091 Knight ...
- POJ题目排序的Java程序
POJ 排序的思想就是根据选取范围的题目的totalSubmittedNumber和totalAcceptedNumber计算一个avgAcceptRate. 每一道题都有一个value,value ...
- HDU 4442 Physical Examination
Physical Examination Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64 ...
- HDU 4442 Physical Examination(贪心)
HDU 4442 Physical Examination(贪心) 题目链接http://acm.split.hdu.edu.cn/showproblem.php?pid=4442 Descripti ...
- hdu 4442 Physical Examination 贪心排序
Physical Examination Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- CSUOJ 1603 Scheduling the final examination
1603: Scheduling the final examination Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 49 Solved: 1 ...
- 2017 New Year’s Greetings from Sun Yat-sen University
As winter turns to spring, the world around us begins to take on an air of freshness. As 2017 is fa ...
- Divide and conquer:Moo University - Financial Aid(POJ 2010)
Moo University - Financial Aid 其实是老题了http://www.cnblogs.com/Philip-Tell-Truth/p/4926008.html 这一次我们换二 ...
随机推荐
- 【BZOJ1559】[JSOI2009]密码(AC自动机,动态规划,搜索)
[BZOJ1559][JSOI2009]密码(AC自动机,动态规划,搜索) 题面 BZOJ 洛谷 题解 首先求方案数显然是构建\(AC\)自动机之后再状压\(dp\),似乎没有什么好讲的. 现在考虑答 ...
- 同一台机器安装多个MySQL服务
在同一个服务器上面安装多个MySQL服务,甚至是安装多个不同版本(比如5.7和5.7.5.7和8.0.12),关键在于区分安装目录.数据目录和使用端口等. 可以下面步骤 安装MySQL1 wget h ...
- Mac安装mysql8.0.12
···shell 下载 wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.12-macos10.13-x86_64.tar.gz ...
- VirtualBox安装Centos后实现文件夹共享
不同虚拟机中的系统和windows之间实现文件共享方式也不一样,在VMWare虚拟机请参考链接:http://www.cnblogs.com/vincentfu/p/5402666.html 进入主题 ...
- JQuery中2个等号与3个等号的区别
首先,== equality 等同,=== identity 恒等.==, 两边值类型不同的时候,要先进行类型转换,再比较.===,不做类型转换,类型不同的一定不等. 下面分别说明:先说 ===,这个 ...
- angularJs的各种服务和指令的使用场景
$location服务,获取页面跳转带的参数 比如说页面是这样的 localhost:9102/admin/goods.html#?id=123 如何获取这个id=123的值呢?????(注意: ...
- 实现vue2.0响应式的基本思路
最近看了vue2.0源码关于响应式的实现,以下博文将通过简单的代码还原vue2.0关于响应式的实现思路. 注意,这里只是实现思路的还原,对于里面各种细节的实现,比如说数组里面数据的操作的监听,以及对象 ...
- Nginx学习总结
2017年2月23日, 星期四 Nginx学习总结 Nginx是目前比较主流的HTTP反向代理服务器(其企业版提供了基于TCP层的反向代理插件),对于构建大型分布式web应用,具有举足轻重的作用.简单 ...
- HTML5 移动开发(CSS3设计移动页面样式)
1.如何创建CSS样式表 2.CSS3的卓越特性 3.基于设备属性改变样式的媒体查询 4.如何使用属性改变元标签创建更美观移动页面 层叠样式表是移动WEB开发中的一个重要组成部分,本次分享将学到如 ...
- es6笔记(3.1)三个点的“...”的作用
展开运算符(spread operator) ES6中"..."的作用之一是,展开运算符. 顾名思义,它的作用是把某些结合数据展开. 在Array.Object.Set和Map上都 ...