博客
关于我
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 分页语句 Limit原理
查看>>
MySql 创建函数 Error Code : 1418
查看>>
MySQL 创建新用户及授予权限的完整流程
查看>>
mysql 创建表,不能包含关键字values 以及 表id自增问题
查看>>
mysql 删除日志文件详解
查看>>
mysql 判断表字段是否存在,然后修改
查看>>
MySQL 到底能不能放到 Docker 里跑?
查看>>
mysql 前缀索引 命令_11 | Mysql怎么给字符串字段加索引?
查看>>
MySQL 加锁处理分析
查看>>
mysql 协议的退出命令包及解析
查看>>
mysql 参数 innodb_flush_log_at_trx_commit
查看>>
mysql 取表中分组之后最新一条数据 分组最新数据 分组取最新数据 分组数据 获取每个分类的最新数据
查看>>
MySQL 命令和内置函数
查看>>
MySQL 和 PostgreSQL,我到底选择哪个?
查看>>
mysql 四种存储引擎
查看>>
MySQL 在并发场景下的问题及解决思路
查看>>
MySQL 在控制台插入数据时,中文乱码问题的解决
查看>>
MySQL 基础架构
查看>>
MySQL 基础模块的面试题总结
查看>>
MySQL 处理插入重主键唯一键重复值办法
查看>>