蓝桥杯VIP算法训练-轨道炮-看完秒懂的(c++map)

该博客介绍了蓝桥杯竞赛中的一道问题,涉及使用C++和map解决轨道炮消灭敌方单位的最大数量。通过分析每个单位的初始位置、方向和速度,确定最佳射击时机,利用unordered_map记录每个时间点的重合单位数量,从而找到消灭单位最多的策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

小明在玩一款战争游戏。地图上一共有 N 个敌方单位,可以看作 2D 平面上的点。其中第 i 个单位在 0 时刻的位置是 (Xi, Yi),方向是 Di (上下左右之一, 用’U’/’D’/’L’/’R’ 表示),速度是 Vi。小明的武器是轨道炮,只能使用一次,不过杀伤力巨大。小明可以选择在某个非负整数时刻释放轨道炮,轨道炮一次可以消灭在一条直线 (平行于坐标轴) 上的所有敌方单位。请你计算小明最多能消灭多少敌方单位。

输入

输入第一行包含一个整数 N。

以下 N 行每行包含 3 个整数 Xi, Yi, Vi,以及一个大写字符 Di。

输出

输出一个整数代表答案。

样例输入复制

4
0 0 1 R
0 10 1 R
10 10 2 D
2 3 2 L

样例输出复制

3

提示

对于所有评测用例,1 ≤ N ≤ 1000, 1000000 ≤ Xi, Yi ≤ 1000000,0 ≤ Vi ≤1000000。

看题找算法:

典型map题目

思路:

1.首先横向射和纵向射是分立的问题,可以分别解决然后取最大值。

2.单个方向上问题就是:给定初始位置和速度,求一个时间和位置使得在这个时间和位置上重合的点最多。

3.因为n只有1000,两两求出相遇时间以及位置,取答案最大的时间和位置即可。


注意事项:

注意细节

#include

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

怀化第一深情

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值