P9241 [蓝桥杯 2023 省 B] 飞机降落

题目描述

题解

这道题数据范围很小,所以可以用搜索做。具体题解看下方代码。

代码

带注释版代码

c 复制代码
#include<iostream>
#include<cstring>
using namespace std;

const int N=10;

struct Plane{ // 存每个飞机的t,d,l 
	int t;
	int d;
	int l;
}planes[N];

int n;
bool st[N]; // 用来判断该飞机有没有降落 

bool dfs(int u,int last){ // u代表当前降落飞机数,last代表当前的时间 
	if(u==n){ // 如果降落了n个飞机,说明所有飞机安全降落 
		return true;
	}
	// dfs有n条分支(当前可以选择n个飞机进行降落) 
	for(int i=0;i<n;i++){
		// 如果!st[i]代表飞机没有降落,
		// 并且飞机达到的时间和盘旋的时间大于当前的时间,就说明这个飞机是安全的(没有到达或者正在盘旋中) 
		if(!st[i]&&planes[i].t+planes[i].d>=last){
			st[i]=true; // 飞机降落
			// 下一个飞机进行降落,并且当前时间要进行更新。
			// last更新是,如果last大于飞机到达时间的话,则该飞机在last时刻降落,并耗时l时,last更新为last+l
			// 如果last小于飞机到达时间的话,那么需要等飞机到达后再降落,所有last更新为t+l时
			// 如果所有飞机都安全降落了,即u==n,return true,那么dfs回溯时,下方条件判断为true,也return true,终止后续递归 
			if(dfs(u+1,max(last,planes[i].t)+planes[i].l))return true;
			// 回溯要把修改复原 
			st[i]=false;
		}
	}
	// 如果当前找不到降落的飞机,返回false 
	return false;
}

int main(){
	int T;
	cin>>T;
	for(int i=0;i<T;i++){
		cin>>n;
		for(int j=0;j<n;j++){
			int t,d,l;
			cin>>t>>d>>l;
			planes[j]={t,d,l};
		} 
		cout<<(dfs(0,0)?"YES":"NO")<<endl;
		// 因为上面的dfs满足u==n,会直接return true,并层层回溯返回true,
		//这个时候不会将修改复原(st[i]=false),所以要把可能存在的st[i]==true的情况消灭,重新初始化一下st数组 
		memset(st,0,sizeof st);
	}
}

不带注释版代码

c 复制代码
#include<iostream>
#include<cstring>
using namespace std;

const int N=10;

struct Plane{
	int t;
	int d;
	int l;
}planes[N];

int n;
bool st[N];

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

int main(){
	int T;
	cin>>T;
	for(int i=0;i<T;i++){
		cin>>n;
		for(int j=0;j<n;j++){
			int t,d,l;
			cin>>t>>d>>l;
			planes[j]={t,d,l};
		} 
		cout<<(dfs(0,0)?"YES":"NO")<<endl;
		memset(st,0,sizeof st);
	}
}
相关推荐
dyxal4 小时前
决策树:让机器像人类一样做选择的“思维导图”
算法·决策树·机器学习
LYFlied4 小时前
【每日算法】LeetCode148. 排序链表
前端·数据结构·算法·leetcode·链表
长安er4 小时前
LeetCode198打家劫舍:从回溯到动态规划的优化历程
算法·leetcode·动态规划·回溯·打家劫舍
代码游侠4 小时前
学习笔记——线程
linux·运维·开发语言·笔记·学习·算法
又是忙碌的一天4 小时前
八大排序之:冒泡排序、快速排序和堆排序
数据结构·算法·排序算法
一直都在5724 小时前
数据结构入门:哈希表和树结构
数据结构·算法·散列表
宵时待雨4 小时前
C语言笔记归纳19:动态内存管理
java·开发语言·算法
喇一渡渡4 小时前
Java力扣---滑动窗口(2)
算法·leetcode·职场和发展
智驱力人工智能5 小时前
山区搜救无人机人员检测算法 技术攻坚与生命救援的融合演进 城市高空无人机人群密度分析 多模态融合无人机识别系统
人工智能·深度学习·算法·架构·无人机·边缘计算
郝学胜-神的一滴5 小时前
OpenGL中的glDrawArrays函数详解:从基础到实践
开发语言·c++·程序人生·算法·游戏程序·图形渲染