博客
关于我
agc018B Sports Festival
阅读量:300 次
发布时间:2019-03-01

本文共 1063 字,大约阅读时间需要 3 分钟。

题目链接

题意简述

n n n个人 m m m种运动,每个人给出了喜好每种运动的顺序,越靠前表示越喜欢。现在你需要选取一些运动,每个人会选取这些运动里他最喜欢的那个参加,求参加运动人数最多的运动的参加人数最少是多少。

题解

如果一个运动被 k k k个人选取了,那么删掉其他的运动,这个运动参加的人数不会变少。那么每次删掉参加人数最多的那些运动,取每次删的那种运动人数最小值即可。

代码

#include 
#include
int read(){ int x=0,f=1; char ch=getchar(); while((ch<'0')||(ch>'9')) { if(ch=='-') { f=-f; } ch=getchar(); } while((ch>='0')&&(ch<='9')) { x=x*10+ch-'0'; ch=getchar(); } return x*f;}const int maxn=300;const int inf=0x3f3f3f3f;int n,m,a[maxn+4][maxn+4],in[maxn+4],mx[maxn+4],ans;int main(){ n=read(); m=read(); for(int i=1; i<=n; ++i) { for(int j=1; j<=m; ++j) { a[i][j]=read(); } } ans=n; int cnt=0; while(cnt
now)) { now=mx[j]; } } ans=std::min(ans,now); for(int j=1; j<=m; ++j) { if((!in[j])&&(mx[j]==now)) { in[j]=1; ++cnt; } } } printf("%d\n",ans); return 0;}

转载地址:http://ccwo.baihongyu.com/

你可能感兴趣的文章
Mysql学习总结(19)——Mysql无法创建外键的原因
查看>>
Mysql学习总结(19)——Mysql无法创建外键的原因
查看>>
Mysql学习总结(1)——常用sql语句汇总
查看>>
Mysql学习总结(20)——MySQL数据库优化的最佳实践
查看>>
Mysql学习总结(21)——MySQL数据库常见面试题
查看>>
Mysql学习总结(22)——Mysql数据库中制作千万级测试表
查看>>
Mysql学习总结(23)——MySQL统计函数和分组查询
查看>>
Mysql学习总结(24)——MySQL多表查询合并结果和内连接查询
查看>>
Mysql学习总结(25)——MySQL外连接查询
查看>>
Mysql学习总结(26)——MySQL子查询
查看>>
Mysql学习总结(27)——Mysql数据库字符串函数
查看>>
Mysql学习总结(28)——MySQL建表规范与常见问题
查看>>
Mysql学习总结(29)——MySQL中CHAR和VARCHAR
查看>>
Mysql学习总结(2)——Mysql超详细Window安装教程
查看>>
Mysql学习总结(30)——MySQL 索引详解大全
查看>>
Mysql学习总结(31)——MySql使用建议,尽量避免这些问题
查看>>
Mysql学习总结(32)——MySQL分页技术详解
查看>>
Mysql学习总结(33)——阿里云centos配置MySQL主从复制
查看>>
Mysql学习总结(35)——Mysql两千万数据优化及迁移
查看>>
Mysql学习总结(36)——Mysql查询优化
查看>>