HDU 3744
来源:互联网 发布:java格式化json字符串 编辑:程序博客网 时间:2024/06/06 02:36
我又来啦~
题目描述
HDU每年举办体育赛事。 最令人兴奋的事件之一是万米长跑。
在比赛中,许多学生正在跑步。
那么现在的排名呢?
我们知道,在跑步中,我们按照每个人跑的长度来排名。
所以如果一名球员超出另外一名球员400M(一圈),即他们在赛道上的位置一样的话,但前者的排名比后者要好得多。
现在给予所有人在赛道上的位置和排名名单,你告诉我排名列表是否可靠。
输入:
输入的第一行给出T,代表T组数据(最多110)。
每个案例的第一行有两个参数,n,m。
(1 <= n <= 100,1 <= m <= 40000,n <= m),表示m米运行中有n个玩家。
那么n行描述每个玩家。
每行有两个棋子,Xi,Ri。表示第i名球员在当前圈的xi米运行[0,399],
排名榜上第Ri名。数据确保没有一对学生有相同的Xi或Ri。 起点在第一圈为0。
输出
YES OR NO
思路:
看了题目就像用map来完成逻辑判断,可能其他方法也不错?
map< int int> 记录每个选手的排名和当前位置,题目说数据集每个人的排名唯一,那最终会有一个people数量的匹配集。
利用map的好处是,即使你不是按排名进行输入,
(如:
56 3
50 2
60 4
150 1
)
你也可以通过map的主键来指定某个排名的人.
题目主要让我们进行一个比较
一个跑者对比他后一名的跑者:相对初始位置较小但排名在前
上述情况的总次数与总圈数进行比较,若这种情况发生的次数大于总长可以达到的圈数,则不合理。
这样的话我们先计算可能的最大圈数 ,
最大圈数是 (meters-map[1])/400+1
( 总长-第一名的当前位置)/一圈的距离+1
计算上述情况的次数通过map循环比较得出。
代码如下
#include<iostream>#include<map>using namespace std;int main(){ int T; cin >> T; while (T) { map<int,int> rank; int round; int people; int meters; cin >> people >> meters; for (int i = 0; i < people; i++) { int X, R; cin >> X >> R; rank[R] = X; } round = ((meters - rank[1]) / 400)+1; for (int i = 2; i <= people; i++) { if (rank[i]>rank[i - 1]) round--; } if (round > 0) cout << "YES" << endl; else cout << "NO" << endl; T--; } return 0;}
我觉得使用map很适合理解这个题目~
- HDU 3744
- HDU 3744 水
- hdu
- hdu
- HDU
- hdu ()
- hdu
- hdu
- HDU
- HDU
- hdu
- hdu
- HDU
- Hdu
- hdu
- hdu-
- hdu
- hdu
- memcached四大注意事项(key长度,空格限制,最大item)
- 蜂狂健身-健身房是个好生意
- JavaScript的面向对象
- asynchttpclient学习
- Linux环境下安装JDK
- HDU 3744
- MATLAB笔记
- cookie、session、storage总结
- Mayor's posters 离散化+线段树染色
- java打印等腰三角形,金字塔,for循环嵌套
- 【tyvj1293】小v的红豆(次短路---一条路只能经过一次)
- iOS开发---UIImage和NSData的相互转换
- 实验九 路由器RIP动态路由配置
- Ubuntu14.04与Win10双系统环境的配置(引导, 无线网卡)