蓝桥杯 2023 省B 飞机降落

首先,这题要求的数据量比较少,我们可以考虑考虑暴力解法。

这题可能难在很多情况的考虑,比如说:

现在时间是10,有个飞机20才到,我们是可以干等10分钟。

cpp 复制代码
#include <iostream>
#include <bits/stdc++.h> // 包含通用的 C++ 头文件
using namespace std;

int flat; // 用于标记是否找到了解

// 深度优先搜索函数,用于寻找飞机降落方案
// 参数解释:
// nums: 存储飞机信息的二维向量,每行包含到达时间、盘旋时间和降落时间
// visited: 存储飞机是否被访问过的布尔向量
// now: 当前时间
// num: 已经访问的飞机数量
void dfs(vector<vector<int> >& nums, vector<bool> visited, int now, int num) {
    if(num == visited.size()) { // 如果已经访问了所有飞机,则找到了解
        flat = 1; // 将解标记为已找到
        return; // 返回
    }
    for(int i = 0; i < nums.size(); i++) { // 遍历所有飞机
        if(flat == 1) // 如果已经找到解,则直接返回
            return;
        if(visited[i] == false && nums[i][0] + nums[i][1] >= now) { // 如果当前飞机未访问且可在当前时间到达
            visited[i] = true; // 标记当前飞机为已访问
            // 递归搜索下一个飞机到达的时间,并更新当前时间和已访问飞机数量
            dfs(nums, visited, max(nums[i][0], now) + nums[i][2], num + 1);
            visited[i] = false; // 回溯,标记当前飞机为未访问
        }
    }
}

int main() {
    int t, n, i;
    cin >> t; // 输入测试用例数量

    while(t--) { // 循环处理每个测试用例
        flat = 0; // 初始化解为未找到
        cin >> n; // 输入当前测试用例中的飞机数量
        // 初始化存储飞机信息的二维向量和访问标记向量
        vector<vector<int> > nums(n, vector<int>(3, 0));
        vector<bool> visited(n, false);
        for(i = 0; i < n; i++) {
            // 输入每架飞机的到达时间、盘旋时间和降落时间
            cin >> nums[i][0] >> nums[i][1] >> nums[i][2];
        }
        // 深度优先搜索找到解
        dfs(nums, visited, 0, 0);
        if(flat == 1) // 如果找到了解,则输出YES
            cout << "YES" << endl;
        else // 否则输出NO
            cout << "NO" << endl;
    }
    return 0;
}
相关推荐
楼田莉子1 小时前
C++17新特性:__had_include/属性/求值顺序规则
开发语言·c++·后端
ytttr8732 小时前
OPC UA 协议栈 C 语言实现
c语言·开发语言·mfc
song5012 小时前
Ascend C 算子开发:从入门到上手
c语言·开发语言·图像处理·人工智能·分布式·flutter·交互
小a杰.2 小时前
Ascend C编程语言进阶:高性能算子开发技巧
android·c语言·开发语言
h_a_o777oah3 小时前
状态机+划分型 DP :深度解析K-划分问题下 DP 状态的转移逻辑(洛谷P2679 P2331 附C++代码)
c++·算法·动态规划·acm·状态机dp·划分型dp·滚动数组优化
小a杰.4 小时前
Ascend C算子开发实战 - 从零开始写算子
c语言·开发语言
雪度娃娃4 小时前
Asio异步读写——连接的安全回收问题
开发语言·c++·安全·php
不吃土豆的马铃薯4 小时前
Spdlog 进阶:日志基本控制、日志格式控制、异步记录器
linux·服务器·开发语言·前端·c++
liulilittle5 小时前
TCP UCP:基于卡尔曼滤波的BBR增强型拥塞控制算法
linux·网络·c++·tcp/ip·算法·c·通讯
咩咦5 小时前
C++学习笔记26:static 静态成员
c++·学习笔记·static·静态成员变量·静态成员·静态成员函数