第十四届蓝桥杯省赛C/C++大学B组真题-飞机降落


思路:根据数据范围N<=10猜测用DFS+剪枝,因为菜狗不会状压dp。根据题目,一般这种飞机的题都会用到贪心的思想。思想是每架飞机都要卡极限最早降落时间,从而保证后面的飞机能够有充足时间降落。
代码参考博客@MQy大佬有详细解答

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N = 10;
int n;
struct Plane {
    int t, d, l;
}p[N];

bool vis[N];
bool dfs(int pos, int last){
    if(pos == n) return true;
    for(int i = 0; i < n; ++i){
        int t = p[i].t, d = p[i].d, l = p[i].l;
        if(!vis[i] && t + d >= last){
            vis[i] = true;
            if(dfs(pos + 1, max(last, t) + l)) return true;
            vis[i] = false;
        }
    }
    return false;
}

int main(void){
    int T;
    cin >> T;

    while(T--){
        scanf("%d", &n);
        for(int i = 0; i < n; ++i){
            int t, d, l;
            scanf("%d%d%d", &t, &d, &l);
            p[i] = {t, d, l};
        }

        memset(vis, 0, sizeof vis);
        if(dfs(0,0)) puts("YES");
        else puts("NO");
    }

    return 0;
}
相关推荐
进击的圆儿15 分钟前
【学习笔记05】C++11新特性学习总结(下)
c++·笔记·学习
老侯(Old monkey)18 分钟前
C语言:将字符串逆序存放
c语言·字符串·函数调用
Jayden_Ruan20 分钟前
C++十进制转二进制
数据结构·c++·算法
小何好运暴富开心幸福1 小时前
C++之日期类的实现
开发语言·c++·git·bash
老赵的博客1 小时前
c++ 是静态编译语言
开发语言·c++
lixinnnn.3 小时前
贪心:火烧赤壁
数据结构·c++·算法
Predestination王瀞潞3 小时前
类的多态(Num020)
开发语言·c++
Predestination王瀞潞3 小时前
类的继承(Num019)
开发语言·c++
Nuyoah11klay3 小时前
华清远见25072班C++学习假期10.3作业
c++
say_fall3 小时前
精通C语言(2.结构体)(内含彩虹)
c语言·开发语言·windows