搜尋
首頁後端開發php教程按級別對二元樹進行排序的最少操作數

2471。依等級對二元樹進行排序的最少操作數

難度:

主題:樹、廣度優先搜尋、二元樹

您將獲得一個二元樹的根,其中具有唯一值

在一次操作中,您可以選擇任兩個同一層級的節點並交換它們的值。

傳回使每個等級的值依嚴格遞增順序排序所需的最少操作數.

節點的等級是它與根節點之間的路徑上的邊數。

範例1:

Minimum Number of Operations to Sort a Binary Tree by Level

  • 輸入: root = [1,4,3,7,6,8,5,null,null,null,null,9,null,10]
  • 輸出: 3
  • 說明:
    • 交換 4 和 3。第 2 層變為 [3,4]。
    • 交換 7 和 5。第 3 級變為 [5,6,8,7]。
    • 交換 8 和 7。第 3 級變為 [5,6,7,8]。
    • 我們使用了 3 次操作,因此傳回 3。
    • 可以證明3是最少需要的運算次數。

範例2:

Minimum Number of Operations to Sort a Binary Tree by Level

  • 輸入: root = [1,3,2,7,6,5,4]
  • 輸出: 3
  • 說明:
    • 交換 3 和 2。第 2 層變為 [2,3]。
    • 交換 7 和 4。第 3 層變為 [4,6,5,7]。
    • 交換 6 和 5。第 3 層變為 [4,5,6,7]。
    • 我們使用了 3 次操作,因此傳回 3。
    • 可以證明3是最少需要的運算次數。

範例 3:

Minimum Number of Operations to Sort a Binary Tree by Level

  • 輸入: root = [1,2,3,4,5,6]
  • 輸出: 0
  • 說明:每個等級都已按升序排序,因此傳回 0。

約束:

  • 樹中的節點數量在 [1, 105] 範圍內。
  • 1 5
  • 樹的所有值都是唯一

提示:

  1. 我們可以將值逐級分組並獨立求解每個組。
  2. 進行 BFS 逐層將數值分組。
  3. 找出對每個層級的陣列進行排序的最小交換次數。
  4. 迭代數組時,檢查當前元素,如果不在正確的索引中,則將該元素替換為應該出現的元素的索引。

解:

這個問題是關於以最少的運算元嚴格升序對二元樹的值進行逐級排序。在每次操作中,我們可以交換同一層級的兩個節點的值。目標是確定實現排序順序所需的此類操作的最少數量。

要點:

  1. 二元樹等級:二元樹的每個等級都應具有嚴格按升序排序的值。
  2. 唯一值:所有節點都有唯一值,由於沒有重複項,因此排序更容易。
  3. 用於層級分組的 BFS:使用廣度優先搜尋 (BFS) 遍歷樹並按層級將節點分組。
  4. 最小交換次數:對於每個級別,我們需要找到對該級別的節點值進行排序所需的最小交換次數。
  5. 約束:樹最多可以有 10^5 個節點,因此解必須有效率。

方法:

  1. BFS 遍歷:執行 BFS 遍歷樹並收集每一層節點的值。
  2. 對每個級別進行排序:對於每個級別,計算按嚴格升序對值進行排序的最小交換次數。
  3. 循環分解:最小化交換的關鍵觀察是,對陣列進行排序可以看作是循環中交換元素。每個循環錯放元素的最小交換次數是循環長度減一。
  4. 累積掉期:將每個等級的掉期相加,得到所需的掉期總數。

計劃:

  1. BFS:使用 BFS 遍歷樹,收集每一層的節點。
  2. 將每個等級排序:對每個等級的值進行排序並計算最小交換次數。
  3. 計算交換:使用循環分解來找到對每個層級的節點進行排序所需的最小交換。

讓我們用 PHP 實作這個解:2471。依等級對二元樹進行排序的最少操作數

<?php /**
 * @param TreeNode $root
 * @return Integer
 */
function minimumOperations($root) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

/**
 * Function to calculate minimum swaps to sort an array
 *
 * @param $arr
 * @return int
 */
function minSwapsToSort($arr) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}
?>

解釋:

  1. 第1步:執行BFS以層級將節點分組:

    • 從根開始,逐層遍歷樹。
    • 對於每個節點,將其值附加到層級數組中的對應層級。
  2. 第 2 步:對於每個級別,計算對值進行排序的最小交換:

    • 對每個層級的值進行排序。
    • 使用基於循環的方法來計算將當前層級轉換為排序層級所需的最小交換。
  3. 循環分解:

    • 對於每個未排序的元素,追蹤其循環(即它應該去的地方)並將元素標記為已存取。
    • 對於每個週期,所需的交換次數是週期長度減一。
  4. 回傳交換總數:

    • 對每個等級所需的交換量求和並回傳總數。

演練範例:

範例1:

輸入樹:

<?php /**
 * @param TreeNode $root
 * @return Integer
 */
function minimumOperations($root) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

/**
 * Function to calculate minimum swaps to sort an array
 *
 * @param $arr
 * @return int
 */
function minSwapsToSort($arr) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}
?>

等級

  • 0級:[1]
  • 1 級:[4, 3]
  • 2 級:[7,6,8,5]
  • 3 級:[9, 10]
  1. 1 級: [4, 3]

    • 將其排序為 [3, 4],並進行 1 次交換(交換 4 和 3)。
  2. 2 級:[7,6,8,5]

    • 將其排序為 [5, 6, 7, 8],並進行 2 次交換(交換 7 和 5,交換 8 和 7)。
  3. 3 級: [9, 10]

    • 已排序,無需交換。

總交換次數 = 1(1 級)2(2 級)= 3 次交換。

輸出:3

範例2:

輸入樹:

        1
       / \
      4   3
     / \ / \
    7  6 8  5
             \
              9
               \
                10

等級

  • 0級:[1]
  • 1 級:[3, 2]
  • 2 級:[7,6,5,4]
  1. 1 級: [3, 2]

    • 將其排序為 [2, 3],並進行 1 次交換(交換 3 和 2)。
  2. 2 級:[7,6,5,4]

    • 將其排序為 [4, 5, 6, 7],並進行 2 次交換(交換 7 和 4,交換 6 和 5)。

總交換次數 = 1(1 級)2(2 級)= 3 次交換。

輸出:3

時間複雜度:

  1. BFS: O(N) 其中 N 是樹中的節點數。
  2. 對每個等級進行排序:對每個等級的值進行排序需要O(L log L),其中L 是目前層級的節點數。在最壞的情況下,總排序複雜度為 O(N log N).
  3. 循環分解:每個等級O(L)

因此,總體時間複雜度為O(N log N),在給定約束的情況下,這已經足夠高效了。

輸出範例:

對於輸入樹:

<?php /**
 * @param TreeNode $root
 * @return Integer
 */
function minimumOperations($root) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

/**
 * Function to calculate minimum swaps to sort an array
 *
 * @param $arr
 * @return int
 */
function minSwapsToSort($arr) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}
?>

輸出為 3 次交換,如範例中詳述。

此解決方案透過使用 BFS 按層級對節點進行分組並循環分解來有效計算對二元樹的每個層級進行排序所需的最小交換次數,以最小化交換次數。 O(N log N) 的時間複雜度是處理最多具有 10^5 個節點的樹的最佳選擇。

聯絡連結

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

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

  • 領英
  • GitHub

以上是按級別對二元樹進行排序的最少操作數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
優化PHP代碼:減少內存使用和執行時間優化PHP代碼:減少內存使用和執行時間May 10, 2025 am 12:04 AM

TooptimizePHPcodeforreducedmemoryusageandexecutiontime,followthesesteps:1)Usereferencesinsteadofcopyinglargedatastructurestoreducememoryconsumption.2)LeveragePHP'sbuilt-infunctionslikearray_mapforfasterexecution.3)Implementcachingmechanisms,suchasAPC

PHP電子郵件:分步發送指南PHP電子郵件:分步發送指南May 09, 2025 am 12:14 AM

phpisusedforsendendemailsduetoitsignegrationwithservermailservicesand andexternalsmtpproviders,自動化intifications andMarketingCampaigns.1)設置設置yourphpenvenvironnvironnvironmentwithaweberswithawebserverserververandphp,確保themailfunctionisenabled.2)useabasicscruct

如何通過PHP發送電子郵件:示例和代碼如何通過PHP發送電子郵件:示例和代碼May 09, 2025 am 12:13 AM

發送電子郵件的最佳方法是使用PHPMailer庫。 1)使用mail()函數簡單但不可靠,可能導致郵件進入垃圾郵件或無法送達。 2)PHPMailer提供更好的控制和可靠性,支持HTML郵件、附件和SMTP認證。 3)確保正確配置SMTP設置並使用加密(如STARTTLS或SSL/TLS)以增強安全性。 4)對於大量郵件,考慮使用郵件隊列系統來優化性能。

高級PHP電子郵件:自定義標題和功能高級PHP電子郵件:自定義標題和功能May 09, 2025 am 12:13 AM

CustomHeadersheadersandAdvancedFeaturesInphpeMailenHanceFunctionalityAndreliability.1)CustomHeadersheadersheadersaddmetadatatatatataatafortrackingandCategorization.2)htmlemailsallowformattingandttinganditive.3)attachmentscanmentscanmentscanbesmentscanbestmentscanbesentscanbesentingslibrarieslibrarieslibrariesliblarikelikephpmailer.4)smtppapapairatienticationaltication enterticationallimpr

使用PHP和SMTP發送電子郵件的指南使用PHP和SMTP發送電子郵件的指南May 09, 2025 am 12:06 AM

使用PHP和SMTP發送郵件可以通過PHPMailer庫實現。 1)安裝並配置PHPMailer,2)設置SMTP服務器細節,3)定義郵件內容,4)發送郵件並處理錯誤。使用此方法可以確保郵件的可靠性和安全性。

使用PHP發送電子郵件的最佳方法是什麼?使用PHP發送電子郵件的最佳方法是什麼?May 08, 2025 am 12:21 AM

ThebestapproachforsendingemailsinPHPisusingthePHPMailerlibraryduetoitsreliability,featurerichness,andeaseofuse.PHPMailersupportsSMTP,providesdetailederrorhandling,allowssendingHTMLandplaintextemails,supportsattachments,andenhancessecurity.Foroptimalu

PHP中依賴注入的最佳實踐PHP中依賴注入的最佳實踐May 08, 2025 am 12:21 AM

使用依賴注入(DI)的原因是它促進了代碼的松耦合、可測試性和可維護性。 1)使用構造函數注入依賴,2)避免使用服務定位器,3)利用依賴注入容器管理依賴,4)通過注入依賴提高測試性,5)避免過度注入依賴,6)考慮DI對性能的影響。

PHP性能調整技巧和技巧PHP性能調整技巧和技巧May 08, 2025 am 12:20 AM

phpperformancetuningiscialbecapeitenhancesspeedandeffice,whatevitalforwebapplications.1)cachingwithapcureduccureducesdatabaseloadprovesrovessetimes.2)優化

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

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

熱工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中