【洛谷 P8695】[蓝桥杯 2019 国 AC] 轨道炮 题解(映射+模拟+暴力枚举+桶排序)

[蓝桥杯 2019 国 AC] 轨道炮

题目描述

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

输入格式

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

以下 N N N 行每行包含 3 3 3 个整数 X i X_i Xi, Y i Y_i Yi, V i V_i Vi,以及一个大写字符 D i D_i Di。

输出格式

输出一个整数代表答案。

样例 #1

样例输入 #1

复制代码
4
0 0 1 R
0 10 1 R
10 10 2 D
2 3 2 L

样例输出 #1

复制代码
3

提示

对于所有评测用例, 1 ≤ N ≤ 1000 1 \le N \le 1000 1≤N≤1000, − 1 0 6 ≤ X i , Y i ≤ 1 0 6 -10^6 \le X_i, Y_i \le 10^6 −106≤Xi,Yi≤106, 0 ≤ V i ≤ 1 0 6 0 \le V_i \le 10^6 0≤Vi≤106。

蓝桥杯 2019 年国赛 A 组 H 题(C 组 J 题)


思路

首先定义一些常量、变量和数据结构。其中,N 是单位的最大数量,T 是模拟的最大时间。定义了一个 Unit 结构体,表示单位,包括单位的位置 (x, y),速度 v 和方向 d。定义了两个哈希表 cntXcntY,用于记录每个坐标上的单位数量。定义了一个哈希表 dir,用于记录每个方向的位移。

接着从输入中读取单位数量 n 和每个单位的信息,包括位置、速度和方向。然后进行 T 轮模拟,每轮模拟中,首先清空 cntXcntY,然后对每个单位进行移动,并更新 cntXcntY

cntXcntY 可以看作是桶,键是坐标,值是该坐标上的单位数量。对于每个单位,根据其位置更新 cntXcntY,将单位分布到桶中。然后找出 cntXcntY 中的最大值,更新最大消灭单位数量 ans

最后输出 ans


AC代码

cpp 复制代码
#include <algorithm>
#include <cmath>
#include <iostream>
#include <map>
#define AUTHOR "HEX9CF"
using namespace std;
using ll = long long;

const int N = 2e6 + 7;
const int T = 4e2 + 7;
const int INF = 0x3f3f3f3f;
const ll MOD = 1e9 + 7;

int n;
map<int, ll> cntX, cntY;
map<char, pair<int, int>> dir;

struct Unit {
	int x, y;
	int v;
	char d;
} unit[N];

void init() {
	dir.clear();
	dir['L'] = {-1, 0};
	dir['R'] = {1, 0};
	dir['U'] = {0, 1};
	dir['D'] = {0, -1};
}

int main() {
	ios::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);

	init();

	cin >> n;
	for (int i = 1; i <= n; i++) {
		int x, y, v;
		char d;
		cin >> x >> y >> v >> d;
		unit[i] = {x, y, v, d};
	}
	ll ans = 0;
	for (int t = 0; t <= T; t++) {
		cntX.clear();
		cntY.clear();
		for (int i = 1; i <= n; i++) {
			auto u = unit[i];
			cntX[u.x]++;
			cntY[u.y]++;
		}
		ll maxi = 0;
		for (const auto i : cntX) {
			maxi = max(maxi, i.second);
		}
		for (const auto i : cntY) {
			maxi = max(maxi, i.second);
		}
		// cout << maxi << endl;
		ans = max(ans, maxi);
		for (int i = 1; i <= n; i++) {
			int v = unit[i].v;
			auto dd = dir[unit[i].d];
			unit[i].x += v * dd.first;
			unit[i].y += v * dd.second;
		}
	}
	cout << ans << "\n";
	return 0;
}

相关推荐
im_AMBER11 分钟前
Leetcode 47
数据结构·c++·笔记·学习·算法·leetcode
kyle~21 分钟前
算法数学---差分数组(Difference Array)
java·开发语言·算法
橘颂TA1 小时前
机器人+工业领域=?
算法·机器人
GilgameshJSS1 小时前
STM32H743-ARM例程40-U_DISK_IAP
c语言·arm开发·stm32·单片机·嵌入式硬件
No0d1es1 小时前
电子学会青少年软件编程(C/C++)1级等级考试真题试卷(2025年9月)
java·c语言·c++·青少年编程·电子学会·真题·一级
小O的算法实验室2 小时前
2025年TRE SCI1区TOP,随机环境下无人机应急医疗接送与配送的先进混合方法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
程序员杰哥2 小时前
软件测试之压力测试详解
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·压力测试
小白程序员成长日记2 小时前
2025.11.06 力扣每日一题
算法·leetcode
暴风鱼划水2 小时前
算法题(Python)数组篇 | 4.长度最小的子数组
python·算法·力扣
gugugu.2 小时前
算法:二分算法类型题目总结---(含二分模版)
算法