当前位置: 首页 > news >正文

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

题目描述

在这里插入图片描述

题解

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

代码

带注释版代码

#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);
	}
}

不带注释版代码

#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);
	}
}

相关文章:

  • 第44天:WEB攻防-PHP应用SQL盲注布尔回显延时判断报错处理增删改查方式
  • SpaceSync智能排班:重构未来办公空间的神经中枢
  • AI对前端开发的冲击
  • msf(Metasploit)中Session与Channel的区别与关系解析
  • 微信小程序项目 tabBar 配置问题:“pages/mine/mine“ need in [“pages“]
  • 计算机硬件与体系结构
  • set_max_delay
  • 康谋应用 | 基于多传感器融合的海洋数据采集系统
  • ROS动态调参
  • 【论文阅读】LightTS:少即是多:基于轻采样的MLP结构的快速多元时间序列预测
  • 信号处理之插值、抽取与多项滤波
  • 第16届计算智能与软件工程国际研讨会(CISE 2026)
  • MAC地址
  • 【设计模式】从事件驱动到即时更新:掌握观察者模式的核心技巧
  • 【MySQL】基本操作 —— DDL
  • C#枚举(Enum)详解
  • 10✨让笔迹突破语言壁垒!Manus AI 多语言识别开启智能书写新纪元
  • CMD批处理一些冷门命令,编写windows脚本常用?
  • vue3+setup组件封装及传值
  • 第2章、WPF窗体及其属性
  • 首届巴塞尔艺术奖公布:大卫·哈蒙斯、曹斐等36人获奖
  • 第十届青春文学奖揭晓,梁晓声获特别奖
  • 上博东馆常设陈列入选全国博物馆“十大精品”
  • 浙江美术馆馆长人民日报撰文:打开更辽阔的审美场域
  • 从近200件文物文献里,回望光华大学建校百年
  • 六省会共建交通枢纽集群,中部六省离经济“第五极”有多远?