題目描述 地址https://www.acwing.com/problem/content/35/
輸入兩棵二叉樹A,B,判斷B是否是A的子結構。node
咱們規定空樹不是任何樹的子結構。算法
樣例spa
樹A: 8 / \ 8 7 / \ 9 2 / \ 4 7 樹B: 8 / \ 9 2 返回 true ,由於B是A的子結構。
算法1
一看到題目就想到 首先遍歷A樹(hasSubtree())
以每一個點做爲根節點和B樹的節點比較 看看是否相同(issame())
若是和B樹每一個節點的值都相同(issame() 遞歸到B樹節點爲NULL) 那麼就是有B結構的子樹code
C++ 代碼blog
/** * 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 IsSame(TreeNode* pRoot1, TreeNode* pRoot2) { if( pRoot2 == NULL) return true; if( pRoot1 == NULL ) return false; if(pRoot1->val != pRoot2->val) return false; return IsSame(pRoot1->left ,pRoot2->left) && IsSame(pRoot1->right,pRoot2->right); } bool hasSubtree(TreeNode* pRoot1, TreeNode* pRoot2) { if ( NULL == pRoot1 || NULL == pRoot2) return false; if( IsSame(pRoot1,pRoot2) ) return true; if( hasSubtree(pRoot1->right,pRoot2) ) return true; if( hasSubtree(pRoot1->left,pRoot2) ) return true; return false; } }; 做者:defddr 連接:https://www.acwing.com/solution/acwing/content/3540/ 來源:AcWing 著做權歸做者全部。商業轉載請聯繫做者得到受權,非商業轉載請註明出處。