赞
踩
N N N 架飞机准备降落到某个只有一条跑道的机场。其中第 i i i 架飞机在 T i T_{i} Ti 时刻到达机场上空,到达时它的剩余油料还可以继续盘旋 D i D_{i} Di 个单位时间,即它最早可以于 T i T_{i} Ti 时刻开始降落,最晩可以于 T i + D i T_{i}+D_{i} Ti+Di 时刻开始降落。降落过程需要 L i L_{i} Li 个单位时间。
一架飞机降落完毕时,另一架飞机可以立即在同一时刻开始降落,但是不能在前一架飞机完成降落前开始降落。
请你判断 N N N 架飞机是否可以全部安全降落。
输入包含多组数据。
第一行包含一个整数 T T T,代表测试数据的组数。
对于每组数据,第一行包含一个整数 N N N。
以下 N N N 行,每行包含三个整数 T i , D i , L i T_{i},D_{i},L_{i} Ti,Di,Li。
对于每组数据,输出 YES
或者 NO
,代表是否可以全部安全降落。
2
3
0 100 10
10 10 10
0 2 20
3
0 10 20
10 10 20
20 10 20
YES
NO
【样例说明】
对于第一组数据,可以安排第 3 架飞机于 0 时刻开始降落,20 时刻完成降落。安排第 2 架飞机于 20 时刻开始降落,30 时刻完成降落。安排第 1 架飞机于 30 时刻开始降落,40 时刻完成降落。
对于第二组数据,无论如何安排,都会有飞机不能及时降落。
【评测用例规模与约定】
对于 30 % 30 \% 30% 的数据, N ≤ 2 N \leq 2 N≤2。
对于 100 % 100 \% 100% 的数据, 1 ≤ T ≤ 10 1 \leq T \leq 10 1≤T≤10, 1 ≤ N ≤ 10 1 \leq N \leq 10 1≤N≤10, 0 ≤ T i , D i , L i ≤ 1 0 5 0 \leq T_{i},D_{i},L_{i} \leq 10^{5} 0≤Ti,Di,Li≤105。
蓝桥杯 2023 省赛 B 组 D 题。
首先从输入中读取测试用例的数量。然后对每个测试用例,执行solve函数。
在solve函数中,首先清除并重置v1向量和vis位集。然后读取飞机的数量n,并读取每架飞机的到达时间、剩余油料(也就是可以盘旋的时间)和降落所需时间,将这些信息存储在v1中。然后尝试对每架飞机执行深度优先搜索(DFS)。
DFS函数尝试将每架飞机按照可能的顺序降落。如果所有飞机都已降落(即vis位集中的1的数量等于n),则返回真(1)。否则,遍历每架飞机,如果飞机已经被访问过(即vis[i]为真)或者飞机的到达时间加上可以盘旋的时间小于当前时间(即不能在当前时间降落),则跳过这架飞机。否则,将这架飞机标记为已访问,并递归调用DFS函数,尝试将其余飞机按照可能的顺序降落。如果成功,即所有飞机都可以降落,那么返回真(1)。否则,将这架飞机标记为未访问,继续尝试其他飞机。
在solve函数中,如果找到一个可以让所有飞机降落的顺序,输出"YES",并返回。否则,输出"NO"。
#include <algorithm>
#include <bitset>
#include <iostream>
#include <vector>
#define AUTHOR "HEX9CF"
using namespace std;
using ll = long long;
const int N = 1e2 + 7;
const int INF = 0x3f3f3f3f;
const ll MOD = 1e9 + 7;
struct Stask {
int t, d, l;
};
int n, m;
vector<Stask> v1;
bitset<N> vis;
bool dfs(int x, int e) {
if (vis.count() == n) {
// 全部降落
return 1;
}
// cout << x << " " << e << endl;
// cout << vis.count() << " " << n << endl;
for (int i = 0; i < n; i++) {
if (vis[i] || v1[i].t + v1[i].d < e) {
// 已访问或不符合要求
continue;
}
vis[i] = 1;
if (dfs(i, max(e, v1[i].t) + v1[i].l)) {
vis[i] = 0;
return 1;
}
vis[i] = 0;
}
return 0;
}
void solve() {
v1.clear();
vis.reset();
cin >> n;
for (int i = 1; i <= n; i++) {
int t, d, l;
cin >> t >> d >> l;
v1.push_back({t, d, l});
}
for (int i = 0; i < n; i++) {
vis[i] = 1;
if (dfs(i, v1[i].t + v1[i].l)) {
cout << "YES"
<< "\n";
return;
}
vis[i] = 0;
}
cout << "NO"
<< "\n";
}
int main() {
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
cin >> m;
while (m--) {
solve();
}
return 0;
}
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。