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

dfs练习

基本模型

void dfs(int step){
	判断边界
	尝试每一种可能 for(i=1;i<=n;i++){
		继续下一步 dfs(step+1)
		}
	返回
}

详细内容:

第十三章 DFS与BFS(保姆级教学!!超级详细的图示!!)_dfs bfs-CSDN博客

实战

题目描述

N 架飞机准备降落到某个只有一条跑道的机场。其中第 i 架飞机在 Ti 时刻到达机场上空,到达时它的剩余油料还可以继续盘旋 Di 个单位时间,即它最早

可以于 Ti 时刻开始降落,最晚可以于 Ti + Di 时刻开始降落。降落过程需要 Li个单位时间。

一架飞机降落完毕时,另一架飞机可以立即在同一时刻开始降落,但是不能在前一架飞机完成降落前开始降落。

请你判断 N 架飞机是否可以全部安全降落。

输入格式

输入包含多组数据。

第一行包含一个整数 T,代表测试数据的组数。

对于每组数据,第一行包含一个整数 N。

以下 N 行,每行包含三个整数:Ti,Di 和 Li。

输出格式

对于每组数据,输出 YES 或者 NO,代表是否可以全部安全降落。

样例输入

复制

2
3
0 100 10
10 10 10
0 2 20
3
0 10 20
10 10 20
20 10 20

样例输出

复制

YES
NO

提示

对于第一组数据,可以安排第 3 架飞机于 0 时刻开始降落,20 时刻完成降落。安排第 2 架飞机于 20 时刻开始降落,30 时刻完成降落。安排第 1 架飞机于 30 时刻开始降落,40 时刻完成降落。

对于第二组数据,无论如何安排,都会有飞机不能及时降落。

对于 30% 的数据,N ≤ 2。

对于 100% 的数据,1 ≤ T ≤ 10,1 ≤ N ≤ 10,0 ≤ Ti , Di , Li ≤ 105。

代码

#include <bits/stdc++.h>
using namespace std;
int T[15];
int D[15];
int L[15];
bool mark[15];
int cnt=0;
bool flag=false;
int sumtime=0;
void dfs(int m)
{
    if(cnt==m){
        flag=true;
        return ;
    }
    for(int i=0;i<m;i++)
    {
        if(mark[i])
        continue;
        if(T[i]+D[i]<sumtime) break;
        int current=sumtime;
        if(sumtime>T[i])
        {
            sumtime+=L[i];
        }
        else
        {
            sumtime=T[i]+L[i];
        }
        mark[i]=true;
        cnt++;
        dfs(m);
        if(flag) break;
         
        cnt--;
        sumtime-=L[i];
        if(sumtime!=current) sumtime=current;
        mark[i]=false;
    }
}
int main()
{
    int n,m;
    cin>>n;
    for(int i=0;i<n;i++)
    {
        cin>>m;
        flag=false;
        cnt=0,sumtime=0;
        for(int i=0;i<m;i++)
        {
            cin>>T[i]>>D[i]>>L[i];
            mark[i]=false;
        }
        dfs(m);
        if(flag) cout<<"YES"<<endl;
        else cout<<"NO"<<endl;
    }
    return 0;
}

相关文章:

  • Automattic 裁员16%,Matt Mullenweg称此举旨在提升盈利能力并增强投资实力
  • ZoomCharts使用方法
  • 线性代数:公共解
  • dolphinscheduler单机部署链接oracle
  • 智慧农业示范园区大数据分析平台整体解决方案
  • 【Easylive】Elasticsearch搜索组件详解
  • Android Input——IMS启动流程(二)
  • ubuntu下的node.js的安装
  • 带Label的韦恩图(vue)
  • 【Java】Maven
  • 【软件测试】自动化测试结合 CI/CD有哪些方案
  • Oracle 数据库查询表广播
  • 青蛙吃虫--dp
  • 【蓝桥杯】动态规划:线性动态规划
  • PhotoShop学习07
  • PostIn V1.0.8版本发布,IDEA 插件支持一键扫描上报,让接口定义不再繁琐
  • leetcode刷题记录44-208. 实现 Trie (前缀树)
  • 指针本质传递偏移动态申请空间 c语言(day05)
  • excel常见错误包括(#N/A、#VALUE!、#REF!、#DIV/0!、#NUM!、#NAME?、#NULL! )
  • 【蓝桥杯】动态规划:背包问题
  • 网警打谣:传播涉刘国梁不实信息,2人被处罚
  • 中国纪检监察刊文:力戒形式主义官僚主义关键是要坚持实事求是
  • 当智慧农场遇见绿色工厂:百事如何用科技留住春天的味道?
  • 霍步刚任辽宁沈阳市委书记
  • 时隔三年,俄乌直接谈判重启
  • 雷军内部演讲回应质疑:在不服输、打不倒方面,没人比我们更有耐心