文的盲刷LeetCode 101. 對(duì)稱二叉樹

題目描述

給定一個(gè)二叉樹,檢查它是否是鏡像對(duì)稱的。

例如,二叉樹 [1,2,2,3,4,4,3] 是對(duì)稱的。

    1
   / \
  2   2
 / \ / \
3  4 4  3

但是下面這個(gè) [1,2,2,null,3,null,3] 則不是鏡像對(duì)稱的:

    1
   / \
  2   2
   \   \
   3    3

題目解答

遞歸比較的思想:

  • 樹對(duì)稱的條件為——根的左子樹的值和右子樹的值成鏡像
  • 所以可以采取兩個(gè)遞歸線路的方法,左子樹的左節(jié)點(diǎn)值與右子樹的右節(jié)點(diǎn)值必較;同樣,左子樹的右節(jié)點(diǎn)值與右子樹的左節(jié)點(diǎn)值必較。若是全部相等,則說明該樹對(duì)稱

代碼:

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */
bool isSame(struct TreeNode* left, struct TreeNode* right) {
    if (left == NULL && right == NULL)
        return true;
    else if (left == NULL || right == NULL)
        return false;
    else if (left->val != right->val)
        return false;
    else
        return isSame(left->left, right->right) &&
        isSame(left->right, right->left);
}
bool isSymmetric(struct TreeNode* root) {
    if (root == NULL)
        return true;
    return isSame(root->left, root->right);
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容