LeetCode 100. Same Tree相同的樹 (C++)

来源:https://www.cnblogs.com/silentteller/archive/2019/05/11/10850542.html
-Advertisement-
Play Games

題目: Given two binary trees, write a function to check if they are the same or not. Two binary trees are considered the same if they are structurally i ...


題目:

Given two binary trees, write a function to check if they are the same or not.

Two binary trees are considered the same if they are structurally identical and the nodes have the same value.

Example 1:

Input:     1         1
          / \       / \
         2   3     2   3

        [1,2,3],   [1,2,3]

Output: true

Example 2:

Input:     1         1
          /           \
         2             2

        [1,2],     [1,null,2]

Output: false

Example 3:

Input:     1         1
          / \       / \
         2   1     1   2

        [1,2,1],   [1,1,2]

Output: false

分析:

給定兩個二叉樹,判斷他們是否相同,相同的二叉樹擁有相同的結構,且節點的值也要相等。

遞歸求解。對於兩個節點是否相同,有如下情況,當兩個節點的左右節點均為空時返回true,如果兩個節點,有一非空時,返回false,如果兩個節點值不同時,返回false,之後遞歸求解節點的左右節點。

程式:

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    bool isSameTree(TreeNode* p, TreeNode* q) {
        if(p == nullptr && q == nullptr) return true;
        if(p == nullptr || q == nullptr) return false;
        if(p->val != q->val) return false;
        return isSameTree(p->left, q->left) && isSameTree(p->right, q->right);
    }
};

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、字體類屬性: 1.字體類型: font-family:字體1,字體2,字體3; 常用寫法: font-family:"微軟雅黑",Arial; 註:a) 多個字體之間用逗號分隔; b)中文字體要放在雙引號中,英文字體由多個單片語成時也要加雙引號; c) 瀏覽器優先識別字體1,如果找不到字體1,識 ...
  • 1. 通過axios實現數據請求 vue.js預設沒有提供ajax功能的。 所以使用vue的時候,一般都會使用axios的插件來實現ajax與後端伺服器的數據交互。 註意,axios本質上就是javascript的ajax封裝,所以會被同源策略限制。 下載地址: axios提供發送請求的常用方法有兩 ...
  • 開 成 都 建 材 發 票微信775130892開 成 都 建 材 發 票微信775130892開 成 都 建 材 發 票微信775130892開 成 都 建 材 發 票微信775130892 開 成 都 建 材 發 票微信775130892開 成 都 建 材 發 票微信775130892開 成 都 ...
  • 裝飾模式概述 定義:動態地給一個對象增加一些附屬的職責。 裝飾裝飾,自然的理解就是在原有物品的基礎上,增加一些別的東西,讓它變得更令人滿意。且裝飾模式是在不改變對象本身的基礎上就行額外的增加,更加靈活。 比如買房,首先買的是個空房,隨後我們會放進去傢具,和各種生活中要用的東西,讓這個家變得更有家的味 ...
  • 支付系統一般需要對接多個支付渠道,一是為了保證系統的可靠性,不能因為單一渠道的問題影響整個支付系統。二是為了提高支付能力,不同渠道提供支付能力不同。三是為了降低支付成本。 對接多個支付渠道以後,為了可以正確選擇支付渠道支付,因此設計渠道路由系統。 從上圖可以看到路由系統功能其實很簡單,分發支付請求到 ...
  • 根據Python官方文檔,您可以強制垃圾收集器釋放未引用的記憶體gc.collect()。例: import gc gc.collect() 根據Python官方文檔,您可以強制垃圾收集器釋放未引用的記憶體gc.collect()。例: import gc gc.collect() 根據Python官方 ...
  • 計數排序: 1、一個非基於比較的排序演算法,該演算法於1954年由 Harold H. Seward 提出,它的優勢在於在對一定範圍內的整數排序, 其時間複雜度為Ο(n+k)(其中k是整數的範圍),快於任何比較排序演算法 2、步驟: a、找出給定整數序列的最大值 max 和最小值 min,創建大小為 ma ...
  • A選項 11 17 34 B選項 22 74 74 C選項 6 7 7 D選項 22 34 17 答案: D選項 解析: 首先,super()函數指的是調用父類的構造方法 ① new B()執行B的構造函數 第一行是super(5); 此時執行的是A的構造函數,A的構造函數調用的是setValue( ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...