搜尋

尋找冠軍 II

Dec 16, 2024 pm 02:24 PM

2924。尋找冠軍 II

難度:

主題:圖表

一場比賽中有n支球隊,編號從0到n-1;每個團隊也是DAG中的一個節點。

給定整數n 和一個0 索引 長度為m 的二維整數數組邊,表示DAG,其中>dges[i] = [u i, vi]表示有來自團隊的有向邊ui 到圖表中的 vi 團隊。

圖中從a到b的有向邊意味著a隊比b隊比a隊

如果沒有b隊比a隊更強,A隊將成為錦標賽的冠軍

如果有唯一冠軍,則返回將成為錦標賽冠軍的隊伍,否則返回-1

筆記

  • 循環 是一系列節點a1, a2, ..., an, an 1 使得節點a1 與節點a1 是同一節點an 1,節點a1, a2, ..., an 是不同的,並且有一個有向對於範圍[1, n].
  • DAG 是一個沒有任何週期的有向圖。

範例1:

Find Champion II

  • 輸入: n = 3,邊 = [[0,1],[1,2]]
  • 輸出: 0
  • 解釋: 1隊比0隊弱,2隊比1隊弱,所以冠軍是0隊。

範例2:

Find Champion II

  • 輸入: n = 4,邊 = [[0,2],[1,3],[1,2]]
  • 輸出: -1
  • 說明: 隊伍 2 比隊伍 0 和隊伍 1 弱。隊伍 3 比隊伍 1 弱。但隊伍 1 和隊伍 0 並不比其他隊伍弱。所以答案是-1。

約束:

    1 m == Edges.length
  • 0 邊[i].length == 2
  • 0 邊[i][0] != 邊[i][1]
  • 產生輸入,如果a隊強於b隊,則b隊不強於a隊。
  • 產生的輸入使得如果a隊強於b隊且b隊強於c隊,則a隊強於c隊。

提示:

  1. 冠軍在 DAG 的入度應為 0。

解:

我們需要在給定的有向無環圖 (DAG) 中辨識 入度 為 0 的團隊。沒有傳入優勢的球隊代表沒有其他球隊比他們更強大的球隊,這使得他們成為冠軍的候選人。如果剛好有一支球隊的入度為0,那麼它就是唯一的冠軍。如果有多個或沒有這樣的團隊,結果為-1。

讓我們用 PHP 實作這個解:2924。尋找冠軍 II

<?php /**
 * @param Integer $n
 * @param Integer[][] $edges
 * @return Integer
 */
function findChampion($n, $edges) {
    // Initialize in-degrees for all teams
    $inDegree = array_fill(0, $n, 0);

    // Calculate the in-degree for each team
    foreach ($edges as $edge) {
        $inDegree[$edge[1]]++;
    }

    // Find teams with in-degree 0
    $candidates = [];
    for ($i = 0; $i < $n; $i++) {
        if ($inDegree[$i] == 0) {
            $candidates[] = $i;
        }
    }

    // If exactly one team has in-degree 0, return it; otherwise, return -1
    return count($candidates) === 1 ? $candidates[0] : -1;
}

// Example 1
$n1 = 3;
$edges1 = [[0, 1], [1, 2]];
echo "Example 1 Output: " . findChampion($n1, $edges1) . PHP_EOL; // Output: 0

// Example 2
$n2 = 4;
$edges2 = [[0, 2], [1, 3], [1, 2]];
echo "Example 2 Output: " . findChampion($n2, $edges2) . PHP_EOL; // Output: -1
?>

解釋:

  1. 輸入解析:

    • n 是團隊數量。
    • Edges 是圖中有向邊的列表。
  2. 初始化入度:

    • 建立一個大小為 n 的陣列 inDegree,初始化為 0。
  3. 計算入度:

    • 對於每條邊 [u, v],增加 v 的入度(v 隊多一個入邊)。
  4. 尋找候選人

    • 迭代 inDegree 陣列並收集入度為 0 的索引。這些索引代表沒有其他更強球隊的球隊。
  5. 決出冠軍

    • 如果剛好有一支隊伍的入度為0,則它是唯一的冠軍。
    • 如果多個團隊或沒有團隊的入度為 0,則回傳 -1。

範例演練

範例1:

  • 輸入:n = 3,邊 = [[0, 1], [1, 2]]
  • 入度:[0, 1, 1]
  • 入度為 0 的團隊:[0]
  • 輸出:0(Team 0 是唯一的冠軍)。

範例2:

  • 輸入:n = 4,邊 = [[0, 2], [1, 3], [1, 2]]
  • 入度:[0, 0, 2, 1]
  • 入度為 0 的團隊:[0, 1]
  • 輸出:-1(有多個潛在冠軍)。

複雜性分析

  1. 時間複雜度:

    • 計算入度:O(m),其中 m 是邊數。
    • 檢查團隊:O(n),其中 n 是隊伍數。
    • 總計:O(n·m)
  2. 空間複雜度:

    • inDegree 陣列:O(n).

這個解決方案非常高效,並且在給定的約束條件下工作。

聯絡連結

如果您發現本系列有幫助,請考慮在 GitHub 上給 存儲庫 一個星號或在您最喜歡的社交網絡上分享該帖子? 。您的支持對我來說意義重大!

如果您想要更多類似的有用內容,請隨時關注我:

  • 領英
  • GitHub

以上是尋找冠軍 II的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
如何使PHP應用程序更快如何使PHP應用程序更快May 12, 2025 am 12:12 AM

tomakephpapplicationsfaster,關注台詞:1)useopcodeCachingLikeLikeLikeLikeLikePachetoStorePreciledScompiledScriptbyTecode.2)MinimimiedAtabaseSqueriSegrieSqueriSegeriSybysequeryCachingandeffeftExting.3)Leveragephp7 leveragephp7 leveragephp7 leveragephpphp7功能forbettercodeefficy.4)

PHP性能優化清單:立即提高速度PHP性能優化清單:立即提高速度May 12, 2025 am 12:07 AM

到ImprovephPapplicationspeed,關注台詞:1)啟用opcodeCachingwithapCutoredUcescriptexecutiontime.2)實現databasequerycachingingusingpdotominiminimizedatabasehits.3)usehttp/2tomultiplexrequlexrequestsandreduceconnection.4 limitesclection.4.4

PHP依賴注入:提高代碼可檢驗性PHP依賴注入:提高代碼可檢驗性May 12, 2025 am 12:03 AM

依赖注入(DI)通过显式传递依赖关系,显著提升了PHP代码的可测试性。1)DI解耦类与具体实现,使测试和维护更灵活。2)三种类型中,构造函数注入明确表达依赖,保持状态一致。3)使用DI容器管理复杂依赖,提升代码质量和开发效率。

PHP性能優化:數據庫查詢優化PHP性能優化:數據庫查詢優化May 12, 2025 am 12:02 AM

DatabasequeryoptimizationinPHPinvolvesseveralstrategiestoenhanceperformance.1)Selectonlynecessarycolumnstoreducedatatransfer.2)Useindexingtospeedupdataretrieval.3)Implementquerycachingtostoreresultsoffrequentqueries.4)Utilizepreparedstatementsforeffi

簡單指南:帶有PHP腳本的電子郵件發送簡單指南:帶有PHP腳本的電子郵件發送May 12, 2025 am 12:02 AM

phpisusedforsenderemailsduetoitsbuilt-inmail()函數andsupportivelibrariesLikePhpMailerAndSwiftMailer.1)usethemail()functionForbasiceMails,butithasimails.2)butithasimail.2)

PHP性能:識別和修復瓶頸PHP性能:識別和修復瓶頸May 11, 2025 am 12:13 AM

PHP性能瓶颈可以通过以下步骤解决:1)使用Xdebug或Blackfire进行性能分析,找出问题所在;2)优化数据库查询并使用缓存,如APCu;3)使用array_filter等高效函数优化数组操作;4)配置OPcache进行字节码缓存;5)优化前端,如减少HTTP请求和优化图片;6)持续监控和优化性能。通过这些方法,可以显著提升PHP应用的性能。

PHP的依賴注入:快速摘要PHP的依賴注入:快速摘要May 11, 2025 am 12:09 AM

依賴性注射(DI)InphpisadesignPatternthatManages和ReducesClassDeptions,增強量強制性,可驗證性和MATIALWINABIOS.ItallowSpasspassingDepentenciesLikEdenciesLikedAbaseConnectionStoclasseconnectionStoclasseSasasasasareTers,interitationAseTestingEaseTestingEaseTestingEaseTestingEasingAndScalability。

提高PHP性能:緩存策略和技術提高PHP性能:緩存策略和技術May 11, 2025 am 12:08 AM

cachingimprovesphpermenceByStorcyResultSofComputationsorqucrouctationsorquctationsorquickretrieval,reducingServerLoadAndenHancingResponsetimes.feftectivestrategiesinclude:1)opcodecaching,whereStoresCompiledSinmememorytssinmemorytoskipcompliation; 2)datacaching datacachingsingMemccachingmcachingmcachings

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具