第十四屆藍橋杯省賽C++B組D題【飛機降落】題解(AC)

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述

解題思路

這道題目要求我們判斷給定的飛機是否都能在它們的油料耗盡之前降落。為了尋找是否存在合法的降落序列,我們可以使用深度優先搜索(DFS)的方法,嘗試所有可能的降落順序。

首先,我們需要理解題目中的條件。每架飛機在 T i T_i Ti? 時刻到達機場上空,剩余油料可以維持 D i D_i Di? 個單位時間,降落需要 L i L_i Li? 個單位時間。這意味著每架飛機可以在 T i T_i Ti? T i + D i T_i+D_i Ti?+Di? 的時間段內開始降落。

然后,我們可以按照以下步驟來實現 DFS:

  1. 首先,我們初始化一個布爾數組 st[] 來記錄每架飛機是否已經降落。
  2. 然后,我們對每架飛機嘗試進行降落。這里的 “嘗試” 意味著我們需要檢查該飛機是否可以在當前的時間內開始降落,即它的開始降落時間是否在 T i T_i Ti? T i + D i T_i+D_i Ti?+Di? 的時間段內。如果可以,我們就讓它降落,并把 st[i] 設置為 true
  3. 在一架飛機降落之后,我們遞歸地對剩下的飛機進行嘗試。這一步就是 DFS 的主要部分,我們需要在所有的可能的降落序列中進行搜索。
  4. 如果在某一步我們發現當前的飛機無法在當前的時間內開始降落,我們就返回 false,并在上一層中嘗試下一架飛機。
  5. 如果所有的飛機都已經降落,我們就返回 true
  6. 最后,我們對所有飛機進行嘗試。如果存在至少一個可以讓所有飛機都降落的序列,我們就輸出 YES,否則輸出 NO

通過以上步驟,我們可以找出是否存在一個合法的降落序列,使得所有的飛機都能在它們的油料耗盡之前降落。

AC_Code

  • C++
#include <iostream>
#include <cstring>
#include <algorithm>using namespace std;const int N = 15;int n;
int a[N], b[N], c[N];
bool st[N];bool dfs(int u, int last, int cnt)
{if (b[u] < last)return false;if (cnt == n)return true;for (int i = 0; i < n; ++ i )if (!st[i]){st[i] = true;if (dfs(i, max(a[u], last) + c[u], cnt + 1))return true;st[i] = false;}return false;
}int main()
{int T;cin >> T;while (T -- ){memset(st, 0, sizeof st);cin >> n;for (int i = 0; i < n; ++ i )cin >> a[i] >> b[i] >> c[i], b[i] += a[i];bool flag = false;for (int i = 0; i < n; ++ i ){st[i] = true;if (dfs(i, 0, 1)){flag = true;break;}st[i] = false;}cout << (flag? "YES": "NO") << endl;}return 0;
}
  • Java
import java.util.*;public class Main {static final int N = 15;static int n;static int[] a = new int[N], b = new int[N], c = new int[N];static boolean[] st = new boolean[N];static boolean dfs(int u, int last, int cnt) {if (b[u] < last) {return false;}if (cnt == n) {return true;}for (int i = 0; i < n; ++i) {if (!st[i]) {st[i] = true;if (dfs(i, Math.max(a[u], last) + c[u], cnt + 1)) {return true;}st[i] = false;}}return false;}public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int T = scanner.nextInt();while (T-- > 0) {Arrays.fill(st, false);n = scanner.nextInt();for (int i = 0; i < n; ++i) {a[i] = scanner.nextInt();b[i] = scanner.nextInt() + a[i];c[i] = scanner.nextInt();}boolean flag = false;for (int i = 0; i < n; ++i) {st[i] = true;if (dfs(i, 0, 1)) {flag = true;break;}st[i] = false;}System.out.println(flag ? "YES" : "NO");}scanner.close();}
}
  • Python
N = 15
a, b, c = [0]*N, [0]*N, [0]*N
st = [False]*Ndef dfs(u, last, cnt):if b[u] < last:return Falseif cnt == n:return Truefor i in range(n):if not st[i]:st[i] = Trueif dfs(i, max(a[u], last) + c[u], cnt + 1):return Truest[i] = Falsereturn FalseT = int(input().strip())
for _ in range(T):st = [False]*Nn = int(input().strip())for i in range(n):a[i], b[i], c[i] = map(int, input().strip().split())b[i] += a[i]flag = Falsefor i in range(n):st[i] = Trueif dfs(i, 0, 1):flag = Truebreakst[i] = Falseprint("YES" if flag else "NO")

【在線測評】

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/38044.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/38044.shtml
英文地址,請注明出處:http://en.pswp.cn/web/38044.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【MotionCap】pycharm 遠程在wsl2 ubuntu20.04中root的miniconda3環境

pycharm wsl2 鏈接到pycharmsbin 都能看到內容,/root 下內容賦予了zhangbin 所有,pycharm還是看不到/root 下內容。sudo 安裝了miniconda3 引發了這些問題 由于是在 root 用戶安裝的miniconda3 所以安裝路徑在/root/miniconda3 里 這導致了環境也是root用戶的,會觸發告警 WA…

沖擊試樣缺口拉刀V2U2U3U5

拉刀性能介紹 沖擊試樣缺口拉刀采用進口高速工具鋼W18Cr4V材質&#xff0c;特殊工藝精密加工制造&#xff0c;硬度高&#xff0c;耐磨性好&#xff0c;使用壽命長&#xff0c;每把拉刀可加工試樣達20&#xff0c;000多個。拉刀共54個齒&#xff08;深度5mm缺口拉刀為74個齒&am…

抖音本地生活服務商條件太高怎么辦?低門檻方法來了!

隨著本地生活賽道的潛力不斷顯現&#xff0c;本地生活服務商的數量也在與日俱增。而在所有開通本地生活服務板塊的互聯網平臺中&#xff0c;日活躍用戶數約8億的抖音往往是眾多創業者優先考慮的對象&#xff0c;以抖音本地生活服務商如何申請為代表的相關問題也因此常出現在多個…

排序算法(1)之插入排序----直接插入排序和希爾排序

個人主頁&#xff1a;C忠實粉絲 歡迎 點贊&#x1f44d; 收藏? 留言? 加關注&#x1f493;本文由 C忠實粉絲 原創 排序之插入排序----直接插入排序和希爾排序(1) 收錄于專欄【數據結構初階】 本專欄旨在分享學習數據結構學習的一點學習筆記&#xff0c;歡迎大家在評論區交流討…

頁面加載503 Service Temporarily Unavailable異常

最近發現網頁刷新經常503&#xff0c;加載卡主&#xff0c;刷新頁面就正常了。 研究之后發現是頁面需要的js文件等加載失敗了。 再研究之后發現是nginx配置的問題。 我之前為了解決一個漏洞檢測到目標主機可能存在緩慢的HTTP拒絕服務攻擊 把nginx的連接設置了很多限制&#…

PHP傳奇游戲推廣信息發布站程序源碼帶會員發布

這是一個游戲導航網站程序。可以做任何一款游戲的推廣發布&#xff0c;會員注冊發布&#xff0c;后臺審核通過&#xff0c;前臺就可以展示&#xff0c;非常不錯的游戲發布平臺

一個項目學習Vue3---響應式基礎

觀察下面一段代碼&#xff0c;學習響應式基礎的全部內容 <template><div><div>將下面的msg屬性放到上面來:{{ msg }}</div><button click"count">{{ count }}</button><button click"object.count.value">{{ o…

關于Autowired

Autowired 是 Spring Framework 中的一個注解&#xff0c;用于自動注入依賴對象。通過這個注解&#xff0c;Spring 可以自動將匹配的 bean 注入到所需的類中&#xff0c;從而實現控制反轉&#xff08;IoC&#xff09;和依賴注入&#xff08;DI&#xff09;。 基本用法 Autowi…

javascript: void(0);用法和常見問題

在JavaScript中&#xff0c;void(0)是一個表達式&#xff0c;它用來獲取一個特殊的值undefined&#xff0c;并且執行一個沒有返回值的操作。這個表達式經常用于創建一個沒有實際返回值的函數調用&#xff0c;或者在需要一個表達式的地方使用&#xff0c;但不希望有任何返回值。…

【Carsim】Carsim2019與Matlab2015b聯合仿真測試

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 這篇文章主要介紹Carsim2019與Matlab2015b聯合仿真測試。 學其所用&#xff0c;用其所學。——梁啟超 歡迎來到我的博客&#xff0c;一起學習&#xff0c;共同進步。 喜歡的朋友可以關注一下&#xff0c…

HTML基礎知識學習指南

HTML基礎知識學習指南 1. 介紹 HTML&#xff08;超文本標記語言&#xff09;是構建網頁的基礎。它是一種標記語言&#xff0c;用于定義網頁的內容和結構。HTML由一系列元素組成&#xff0c;這些元素使用標簽來表示。 2. HTML文檔結構 HTML文檔的基本結構包括以下部分&#…

AI作畫工具深度剖析:Midjourney vs. Stable Diffusion (SD)

在人工智能技術的推動下&#xff0c;藝術創作的邊界被不斷拓寬&#xff0c;AI作畫工具成為數字藝術家與創意人士的新寵。其中&#xff0c;Midjourney與Stable Diffusion&#xff08;SD&#xff09;作為當前領域的佼佼者&#xff0c;以其獨特的算法機制、豐富的功能特性及高質量…

python-糖果俱樂部(賽氪OJ)

[題目描述] 為了慶祝“華為杯”的舉辦&#xff0c;校園中開展了許多有趣的熱身小活動。小理聽到這個消息非常激動&#xff0c;他趕忙去參加了糖果俱樂部的活動。 該活動的規則是這樣的&#xff1a;攤位上有 n 堆糖果&#xff0c;第 i 堆糖果有 ai? 個&#xff0c;參與的同學可…

面向工業化的多類電子元件自動計數系統測試報告

目錄 1、項目描述 2、登錄注冊測試 2、主界面測試 2.1、在線計數測試 2.2、離線計數測試 2.3、瀏覽數據測試 1、項目描述 該系統利用機器視覺平臺采集電子元件圖像&#xff0c;設計并實現了適應不同形態分布的電子元件計數模型&#xff0c;能夠快速且準確地進行計數和分類&…

0139__TCP協議

全網最詳細TCP參數講解&#xff0c;再也不用擔心沒有面試機會了_tcp的參數-CSDN博客 TCP協議詳解-騰訊云開發者社區-騰訊云 TCP-各種參數 - 簡書

【408考點之數據結構】樹形查找

樹形查找 樹形查找是利用樹這種數據結構進行查找操作的方法。樹形查找的主要優勢在于它能夠通過層次結構有效地組織數據&#xff0c;使得查找、插入和刪除操作都能夠高效進行。以下是對樹形查找的詳細總結。 1. 二叉查找樹&#xff08;Binary Search Tree, BST&#xff09; …

第4章:操作系統

第4章&#xff1a;操作系統 操作系統概述 進程管理 在有限的資源下&#xff0c;要保證系統不發生死鎖&#xff0c;則可以按這種邏輯來分析。首先給每個進程分配所需資源數減1個資源&#xff0c;然后系統還有1個資源&#xff0c;則不可能發生死鎖。 線程 存儲管理 虛擬存儲器的…

C++ //練習 14.22 定義賦值運算符的一個新版本,使得我們能把一個表示ISBN的string賦給一個Sales_data對象。

C Primer&#xff08;第5版&#xff09; 練習 14.22 練習 14.22 定義賦值運算符的一個新版本&#xff0c;使得我們能把一個表示ISBN的string賦給一個Sales_data對象。 環境&#xff1a;Linux Ubuntu&#xff08;云服務器&#xff09; 工具&#xff1a;vim 代碼塊 struct Sa…

全面講解GRASP原則

學習目標&#xff1a; 掌握GRASP 學習內容&#xff1a; GRASP&#xff08;General Responsibility Assignment Software Patterns&#xff0c;通用責任分配軟件模式&#xff09;原則是一組設計原則和模式&#xff0c;旨在幫助軟件設計人員合理地分配類和對象的責任。GRASP原則…

昇思25天學習打卡營第九天|使用靜態圖加速

背景 提供免費算力支持&#xff0c;有交流群有值班教師答疑的華為昇思訓練營進入第九天了。 今天是第九天&#xff0c;前八天的學習內容可以看鏈接 昇思25天學習打卡營第一天|快速入門 昇思25天學習打卡營第二天|張量 Tensor 昇思25天學習打卡營第三天|數據集Dataset 昇思25天…