14届蓝桥杯省赛 C/C++ B组 T4 飞机降落 (DFS)



记录此题提醒自己,此类时间轴问题可以通过DFS解决 DFS不是能解决所有题吗

对于此题,我们将降落的飞机的个数和时间轴作为DFS的形参,这样可以节省手动回溯的过程。

并且在DFS的过程中我们要加入一些贪心策略,否则直接爆搜有可能搜不出来答案。

如果一个飞机的到达时刻加上盘旋时间能够超过或者等于上一架飞机降落后的时间,那么就可以降落。

之后要再进行判断,如果这个飞机的到达时间是超过了上一架飞机降落后的时间的,那么就直接把t[i] + l[i]当作下一层的时间,否则的话,把上一个飞机降落的时间加上当前飞机降落的时间当做下一层的时间。

cpp 复制代码
#include<iostream>
#include<cstring>
using namespace std;
const int N = 15;

struct Node {
    int t;
    int d;
    int l;
}a[N];
int flag = 0;
int n;
bool vis[N];

void dfs(int u, int time) {
    if (flag)return;

    if (u == n) {
        flag = 1;
        return;
    }

    for (int i = 1; i <= n; i++) {
        if(!vis[i]){
            if(a[i].t + a[i].d >= time){
                vis[i] = 1;
                if(time > a[i].t)dfs(u+1,time + a[i].l);
                else dfs(u+1,a[i].t + a[i].l);
                vis[i] = 0;
            }
        }
    }
}

int main() {
    int t; cin >> t;

    while (t--) {
        memset(vis,0,sizeof vis);
        cin >> n;

        for (int i = 1; i <= n; i++)cin >> a[i].t >> a[i].d >> a[i].l;

        dfs(0,0);

        if (flag)cout << "YES" << endl;
        else cout << "NO" << endl;
        
        flag = 0;
    }
    return 0;
}
相关推荐
艾莉丝努力练剑21 小时前
【Linux网络】Linux 网络编程:应用层自定义协议与序列化(3):网络计算器实现和守护进程
linux·运维·服务器·网络·c++·计算机网络·安全
千寻girling21 小时前
周日那天参加的力扣周赛... —— 10号
java·javascript·c++·python·算法·leetcode·职场和发展
研究点啥好呢21 小时前
dji机器人SLAM算法工程师 面试题精选:10道高频考题+答案解析
c++·算法·机器人·slam·dji
jllllyuz21 小时前
VC++ 读写 Excel 文件实现
开发语言·c++·excel
小小编程能手21 小时前
C++文件从操作:
开发语言·c++
茉莉玫瑰花茶21 小时前
C++ 17 详细特性解析(6)
开发语言·c++
东方.既白21 小时前
QML与C++炫酷界面交互DEMO
开发语言·c++·交互
承渊政道21 小时前
【贪心算法】(经典实战应用解析(一):柠檬水找零、将数组和减半的最少操作次数、最大数、摆动序列)
数据结构·c++·学习·算法·leetcode·贪心算法·排序算法
少司府21 小时前
C++基础入门:vector深度解析(七千字深度剖析)
c语言·开发语言·数据结构·c++·容器·vector·顺序表
计算机安禾1 天前
【c++面向对象编程】第8篇:const成员与mutable:常对象与常函数
开发语言·javascript·c++