對稱的二叉樹題目描述
請實現乙個函式,用來判斷一顆二叉樹是不是對稱的。注意,如果乙個二叉樹同此二叉樹的映象是同樣的,定義其為對稱的。
class solution
if ((nullptr == proot1) || (nullptr == proot2))
if (proot1->val != proot2->val)
return issymmetrical(proot1->left, proot2->right)
&& issymmetrical(proot1->right, proot2->left);
}bool issymmetrical(treenode* proot)
};
原來想利用中序左右對稱來做, 後來發現不可行, 因為當樹的元素對應值都相同時失效
class solution
if (proot->left != nullptr)
midorder(proot->left);
vt.push_back(proot->val);
if (proot->right != nullptr)
midorder(proot->right);
}bool issymmetrical(treenode* proot)
}return true;
}};
/*
struct treenode
};*/
對稱二叉樹c 對稱的二叉樹
很簡單,關鍵還是知道怎麼樣才能判斷乙個 二叉樹是否對稱,只要採用前序 中序 後序 層次遍歷等任何一種遍歷方法,分為先左後右和先 右後左兩種方法,只要兩次結果相等就說明這棵樹是一顆對稱二叉樹。迭代版本 class solution public bool issymmetric treenode ro...
對稱二叉樹
請實現乙個函式,用來判斷一顆二叉樹是不是對稱的。注意,如果乙個二叉樹同此二叉樹的映象是同樣的,定義其為對稱的。這題還是蠻簡單的。對稱二叉樹 include using namespace std struct treenode bool issymmetrical treenode proot1,t...
對稱二叉樹
請實現乙個函式,用來判斷一顆二叉樹是不是對稱的。注意,如果乙個二叉樹同此二叉樹的映象是同樣的,定義其為對稱的。solution public class treenode 我們可以通過比較二叉樹的前序遍歷序列和對稱前序遍歷序列來判斷二叉樹是不是對稱的 public class solution bo...