207 課程表

題目

你這個學期必須選修 numCourses 門課程,記為 0 到 numCourses - 1 。

在選修某些課程之前需要一些先修課程。 先修課程按數組 prerequisites 給出,其中 prerequisites[i] = [ai, bi] ,表示如果要學習課程 ai 則 必須 先學習課程 bi 。

例如,先修課程對 [0, 1] 表示:想要學習課程 0 ,你需要先完成課程 1 。
請你判斷是否可能完成所有課程的學習?如果可以,返回 true ;否則,返回 false 。

示例

輸入:numCourses = 2, prerequisites = [[1,0]]
輸出:true
解釋:總共有 2 門課程。學習課程 1 之前,你需要完成課程 0 。這是可能的。

解析

這道題首先主要的思路是用bfs來寫,考慮有如下數據:
n = 6,先決條件表:[[3, 0], [3, 1], [4, 1], [4, 2], [5, 3], [5, 4]]
在這里插入圖片描述
對于這種題要構造兩個數據:

  • 每個節點的入度數量
  • 所有的節點構成一張圖,可以用map來表示,每個節點指向了哪些節點,這些節點用一個數組來表示

在此基礎上,不斷的將入度為0的節點放到隊列中消費掉,消費的時候看哪些節點的入度變成了0,則可以加入到隊列中,直到處理完成。

func canFinish(numCourses int, prerequisites [][]int) bool {var (edges  = make(map[int][]int, numCourses) // 邊,也叫鄰接表,存的是每個位置,可以指向后面的哪些位置indeg  = make([]int, numCourses)         // 入度數組result []int)for _, info := range prerequisites {edges[info[1]] = append(edges[info[1]], info[0]) // 邊中存的是每門課程構成的一個圖indeg[info[0]]++                                 // 先計算出每門課程的初始入度值,即在內層數組的下標0位置上出現一次,就代表依賴1位置的課要先上,入度就要+1}queue := []int{}for i := 0; i < numCourses; i++ {if indeg[i] == 0 {queue = append(queue, i) // 所有入度為0的入隊列}}for len(queue) > 0 {u := queue[0]queue = queue[1:]result = append(result, u)   // 表示上了一門入度為0的課,看最后課的總數是否相等for _, v := range edges[u] { // 對于入度為0的數據指向的數據進行遍歷indeg[v]-- // 入度為0的數據消費了,則對應的依賴的這些節點的入度就--if indeg[v] == 0 {queue = append(queue, v)}}}return len(result) == numCourses
}

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

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

相關文章

ArcGIS Pro SDK (七)編輯 13 注解

ArcGIS Pro SDK &#xff08;七&#xff09;編輯 13 注解 文章目錄 ArcGIS Pro SDK &#xff08;七&#xff09;編輯 13 注解1 注釋構建工具2 以編程方式啟動編輯批注3 更新批注文本4 修改批注形狀5 修改批注文本圖形6 接地到網格 環境&#xff1a;Visual Studio 2022 .NET6 …

在 PostgreSQL 中,如何處理數據的版本控制?

文章目錄 一、使用時間戳字段進行版本控制二、使用版本號字段進行版本控制三、使用歷史表進行版本控制四、使用 RETURNING 子句獲取更新前后的版本五、使用數據庫觸發器進行版本控制 在 PostgreSQL 中&#xff0c;處理數據的版本控制可以通過多種方式實現&#xff0c;每種方式都…

ensorFlow是由Google開發的

TensorFlow是由Google開發的一個開源的深度學習框架。它提供了一種靈活且高效的方法來構建、訓練和部署各種機器學習模型。 TensorFlow的基本概念是計算圖&#xff08;computational graph&#xff09;。在TensorFlow中&#xff0c;用戶通過定義計算圖來描述模型的結構和計算流…

JVM(Java虛擬機)詳解(JVM 內存模型、堆、GC、直接內存、性能調優)

JVM&#xff08;Java虛擬機&#xff09; JVM 內存模型 結構圖 jdk1.8 結構圖&#xff08;極簡&#xff09; jdk1.8 結構圖&#xff08;簡單&#xff09; JVM&#xff08;Java虛擬機&#xff09;&#xff1a; 是一個抽象的計算模型。如同一臺真實的機器&#xff0c;它有自己…

思維導圖插件--jsMind的使用

vue引入jsmind&#xff08;右鍵菜單&#xff09;_jsmind.menu.js-CSDN博客 第一版 vue-JsMind思維導圖實現&#xff08;包含鼠標右鍵自定義菜單&#xff09;_jsmind 右鍵菜單-CSDN博客 // 新增節點addNode() {console.log(this.get_selected_nodeid());this.get_selected_…

Vue的學習之數據與方法

前段期間&#xff0c;由于入職原因沒有學習&#xff0c;現在已經正式入職啦&#xff0c;接下來繼續加油學習。 一、數據與方法 文字備注已經在代碼中&#xff0c;方便自己學習和理解 <!DOCTYPE html> <html><head><meta charset"utf-8">&l…

如何使用HippoRAG增強LLM的記憶

大型語言模型&#xff08;LLM&#xff09;已經證明是一種非常寶貴的思考工具。經過大量文本、代碼和其他媒體數據集的訓練&#xff0c;它們能夠創作出接近人類水平的文章、翻譯語言、生成圖像&#xff0c;還能以信息豐富的方式回答人們提出的問題&#xff0c;甚至可以編寫不同類…

SQLite 附加數據庫

SQLite 附加數據庫 SQLite 是一種輕量級的數據庫管理系統,因其小巧、快速和易于使用而廣受歡迎。在 SQLite 中,可以將多個數據庫文件附加到單個數據庫連接中,從而允許用戶在不同的數據庫之間輕松切換和操作數據。本文將詳細介紹如何在 SQLite 中附加數據庫,并探討其使用場…

CANopen協議開發梳理總結筆記教程

0、提醒 CANOpen使用時&#xff0c;需要清楚什么是大端和小端&#xff0c;這對于CANOpen數據發送及解析時&#xff0c;有很大的幫助。且學習開發CANOpen時&#xff0c;需要具備一定的CAN基礎。 1、CANOpen協議介紹 ①、什么是CANOpen協議 CANOpen協議是一種架構在控制局域網絡…

基于CLIP特征的多模態大模型中的視覺短板問題

【論文極速讀】 基于CLIP特征的多模態大模型中的視覺短板問題 FesianXu 20240706 at Tencent WeChat search team 前言 今天讀到篇CVPR 24’的論文 [1]&#xff0c;討論了常見的多模態大模型&#xff08;大多都基于CLIP語義特征&#xff0c;以下簡稱為MLLM&#xff09;中的視覺…

若依 / ruoyi-ui:執行yarn dev 報錯 esnext.set.difference.v2.js in ./src/utils/index.js

一、報錯信息 These dependencies were not found: * core-js/modules/esnext.set.difference.v2.js in ./src/utils/index.js * core-js/modules/esnext.set.intersection.v2.js in ./src/utils/index.js * core-js/modules/esnext.set.is-disjoint-from.v2.js in ./src/utils…

Python處理表格數據常用的 N+個操作

Python作為一種強大且易用的編程語言&#xff0c;其在數據處理方面表現尤為出色。特別是當我們面對大量的表格數據時&#xff0c;Python的各類庫和工具可以極大地提高我們的工作效率。以下&#xff0c;我將詳細介紹Python處理表格數據常用的操作。 首先&#xff0c;我們需要安…

2024.7.5總結

今晚的總結是在圖書館前的梯子上寫的&#xff0c;我多次輾轉&#xff0c;可能是我最后一次看看這個學校了&#xff0c;明天就要踏上回家的旅途了。還有半個月入職&#xff0c;干脆回家看看&#xff0c;畢竟&#xff0c;工作以后機會不多了。 下午的時候&#xff0c;用順豐寄了…

復現YOLO_ORB_SLAM3_with_pointcloud_map項目記錄

文章目錄 1.環境問題2.遇到的問題2.1編譯問題1 monotonic_clock2.2 associate.py2.3 associate.py問題 3.運行問題 1.環境問題 首先環境大家就按照github上的指定環境安裝即可 環境怎么安裝網上大把的資源&#xff0c;自己去找。 2.遇到的問題 2.1編譯問題1 monotonic_cloc…

ASP.NET Core----基礎學習01----HelloWorld---創建Blank空項目

文章目錄 1. 創建新項目--方式一&#xff1a; blank2. 程序各文件介紹&#xff08;Project name &#xff1a;ASP.Net_Blank&#xff09;&#xff08;1&#xff09;launchSettings.json 啟動方式的配置文件&#xff08;2&#xff09;appsettings.json 基礎配置file參數的讀取&a…

ChatGPT:SpringBoot解決跨域問題方法-手動設置請求頭

ChatGPT&#xff1a;SpringBoot解決跨域問題方法-手動設置請求頭 這里的設置響應頭是為了發送請求方還是接收請求方 設置響應頭是為了發送請求方。具體來說&#xff0c;添加 Access-Control-Allow-Origin 頭部是為了告訴瀏覽器&#xff0c;哪些域名可以訪問資源。當設置為 * 時…

Java求自然常數e的近似值(課堂實例1)

??引言&#x1f383;&#x1f383; ?點關注編程夢想家&#xff08;大學生版&#xff09;-CSDN博客不迷路~~~~~~? 自然常數 &#x1d452;e 是數學中一個非常重要的常數&#xff0c;約等于 2.71828&#xff0c;它在自然對數、復合利息計算等領域有著廣泛的應用。本文將介紹如…

自動批量將阿里云盤文件發布成WordPress文章腳本源碼(以RiPro主題為例含付費信息下載地址SEO等自動設置)源碼

背景 很多資源下載站&#xff0c;付費資源下載站&#xff0c;付費內容查看等都可以用WordPress站點發布內容&#xff0c;這些站點一般會基于一個主題&#xff0c;付費信息作為文章附屬的信息發布&#xff0c;底層存儲在WP表里&#xff0c;比如日主題&#xff0c;子比主題等。 …

掌握IPython的`%%debug`:深入交互式調試的藝術

IPython是一個功能豐富的交互式Python解釋器&#xff0c;它為Python開發者提供了許多便捷的功能&#xff0c;其中之一就是%%debug魔法命令。%%debug是IPython提供的一種快速進入調試模式的方法&#xff0c;它允許用戶在代碼執行出錯時立即開始調試&#xff0c;而無需單獨啟動調…

Apache Seata tcc 模塊源碼分析

本文來自 Apache Seata官方文檔&#xff0c;歡迎訪問官網&#xff0c;查看更多深度文章。 本文來自 Apache Seata官方文檔&#xff0c;歡迎訪問官網&#xff0c;查看更多深度文章。 一 .導讀 spring 模塊分析中講到&#xff0c;Seata 的 spring 模塊會對涉及到分布式業務的 b…