亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

數據結構與算法中二叉樹子結構的詳解

2020-01-26 14:10:43
字體:
來源:轉載
供稿:網友

數據結構與算法中二叉樹子結構的詳解

需求

輸入兩棵二叉樹A,B,判斷B是不是A的子結構。(ps:我們約定空樹不是任意一個樹的子結構)

樹的描述:

class TreeNode {  int val = 0;  TreeNode left = null;  TreeNode right = null;  public TreeNode(int val) {    this.val = val;  }}

解決思路

使用了棧將元素入棧,并不斷的彈出元素,彈出一個元素的時候,拼接成字符串,并用特殊符號進行區分,該方法主要是按照先序遍歷的方式將樹節點的數據信息拼接為字符串,這樣,兩個樹的節點拼接而成的串進行判斷是不是包含。

不過,有的資料上說可以通過遞歸的方式進行,但是我感覺以及實踐以后發現是錯誤的。后面會給出代碼,讀者自行嘗試。

public static boolean HasSubtree2(TreeNode root1, TreeNode root2) {    if (root2 == null)      return false;    String str = "";    Stack<TreeNode> stack = new Stack<TreeNode>();    stack.push(null);    stack.push(root1);    TreeNode node = null;    while ((node = stack.pop()) != null) {      str += '_' + node.val + '_';      if (node.right != null) {        stack.push(node.right);      }      if (node.left != null) {        stack.push(node.left);      }    }    String str2 = "";    node = null;    stack.push(null);    stack.push(root2);    while ((node = stack.pop()) != null) {      str2 += '_' + node.val + '_';      if (node.right != null) {        stack.push(node.right);      }      if (node.left != null) {        stack.push(node.left);      }    }    if (str.contains(str2)) {      return true;    } else {      return false;    }  }

樹的構建

二叉樹而言,可以通過數組的方式進行存放,首節點放在數組0號位置處,其左節點在1號位置處,其右節點在2號位置處。由此該index的映射關系為:

index_parent.left => 2* index_parent + 1;
index_parent.right=> 2* index_parent + 2;

構建思路,左節點和右節點分別構建,根節點的左節點就一直追溯其子節點,根節點的右節點一直追溯其子節點,由此,形成的是遞歸的結構。

代碼如下:

注:這里數組中通過-1作為區分,讀者可自行擴充。

public static TreeNode getTree(int[] node, int index) {    if (index >= node.length)      return null;    TreeNode n = null;    if (node[index] != -1) {      n = new TreeNode(node[index]);      n.left = getTree(node, index * 2 + 1);      n.right = getTree(node, index * 2 + 2);    }    return n;  }

完整代碼

包括了資料中提供的代碼,但是經過測試如下用例中是錯誤的,但是理論上說tree2應該是tree1的子結構才對。

import java.util.Stack;public class HasSubtree {  public static void main(String[] args) {    TreeNode tree = getTree(new int[] { 8, 8, 7, 9, 2, -1, -1, -1, -1, 4, 7 }, 0);    TreeNode tree2 = getTree(new int[] { 2, 4, 7 }, 0);    boolean bool = HasSubtree(tree, tree2);    System.out.println(bool);    boolean bool2 = HasSubtree2(tree, tree2);    System.out.println(bool2);  }  public static boolean HasSubtree2(TreeNode root1, TreeNode root2) {    if (root2 == null)      return false;    String str = "";    Stack<TreeNode> stack = new Stack<TreeNode>();    stack.push(null);    stack.push(root1);    TreeNode node = null;    while ((node = stack.pop()) != null) {      str += '_' + node.val + '_';      if (node.right != null) {        stack.push(node.right);      }      if (node.left != null) {        stack.push(node.left);      }    }    String str2 = "";    node = null;    stack.push(null);    stack.push(root2);    while ((node = stack.pop()) != null) {      str2 += '_' + node.val + '_';      if (node.right != null) {        stack.push(node.right);      }      if (node.left != null) {        stack.push(node.left);      }    }    if (str.contains(str2)) {      return true;    } else {      return false;    }  }  public static TreeNode getTree(int[] node, int index) {    if (index >= node.length)      return null;    TreeNode n = null;    if (node[index] != -1) {      n = new TreeNode(node[index]);      n.left = getTree(node, index * 2 + 1);      n.right = getTree(node, index * 2 + 2);    }    return n;  }  public static boolean HasSubtree(TreeNode root1, TreeNode root2) {    boolean result = false;    if (root1 != null && root2 != null) {      if (root1.val == root2.val) {        result = isSubTree(root1, root2);      }      if (!result) {        result = isSubTree(root1.left, root2);      }      if (!result) {        result = isSubTree(root1.right, root2);      }    }    return result;  }  private static boolean isSubTree(TreeNode root1, TreeNode root2) {    if (root1 == null)      return false;    if (root2 == null)      return true;    if (root1.val != root2.val)      return false;    return isSubTree(root1.left, root2.left)        && isSubTree(root1.right, root2.right);  }}class TreeNode {  int val = 0;  TreeNode left = null;  TreeNode right = null;  public TreeNode(int val) {    this.val = val;  }}

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欲色天天网综合久久| 欧美丰满少妇xxxxx| 久久久久久伊人| 欧美黑人巨大xxx极品| 久久久久久午夜| 欧美激情视频网址| 日韩男女性生活视频| 97在线视频免费看| 国产专区欧美专区| 5252色成人免费视频| 国产91av在线| 国产成人综合精品| 日韩中文字幕免费| www亚洲精品| 91精品视频观看| 庆余年2免费日韩剧观看大牛| 国内精品久久久久久中文字幕| 在线观看91久久久久久| 少妇高潮久久77777| 亚洲高清不卡av| 精品久久久久久久久国产字幕| 亚洲免费av电影| 国产日产久久高清欧美一区| 亚洲一区二区三区视频播放| 久久深夜福利免费观看| 成人av电影天堂| 狠狠躁天天躁日日躁欧美| 国产成人aa精品一区在线播放| 国产97色在线|日韩| 日本高清不卡在线| 国产成人极品视频| 国产一区二区三区在线视频| 91久久久久久久久久久| 欧美高清videos高潮hd| 欧美精品免费看| 亚洲一区二区三区久久| 欧美裸体男粗大视频在线观看| 91精品视频在线播放| 亚洲精品久久久久久久久久久| 日韩欧美在线视频| 国产91露脸中文字幕在线| 成人精品视频99在线观看免费| 国产精品男女猛烈高潮激情| 国产精品啪视频| 91香蕉国产在线观看| 精品成人国产在线观看男人呻吟| 欧美成人午夜剧场免费观看| 欧美中文字幕在线视频| 成人午夜在线观看| 亚洲新声在线观看| 欧美日韩成人在线观看| 红桃视频成人在线观看| 亚洲欧洲国产精品| 欧美视频在线观看免费网址| 欧美大片在线看免费观看| 久久人人爽人人爽人人片av高请| 国产精品国产三级国产专播精品人| 日韩av电影手机在线观看| 欧美日韩午夜激情| 亚洲性69xxxbbb| 91精品一区二区| 精品偷拍各种wc美女嘘嘘| 欧美成人国产va精品日本一级| 国产亚洲日本欧美韩国| 久久99青青精品免费观看| 国产精品xxx视频| 亚洲国产97在线精品一区| 欧美日韩国产一区二区| 日韩男女性生活视频| 国产精品三级美女白浆呻吟| 亚洲黄色成人网| 亚洲国内高清视频| 亚洲精品国产suv| 岛国av一区二区三区| 91亚洲国产成人久久精品网站| 欧美性xxxx极品高清hd直播| 欧美一级淫片videoshd| 久久91超碰青草是什么| 久久精品国产69国产精品亚洲| 亚洲欧美日韩爽爽影院| 国产成人亚洲精品| 日韩精品中文在线观看| 国产精品视频专区| 欧美巨乳在线观看| 日韩电影中文 亚洲精品乱码| 欧美成人激情在线| 欧美在线xxx| 亚洲japanese制服美女| 日韩美女视频在线观看| 伊人激情综合网| 国产成人精品免费久久久久| 久久免费精品视频| 国产精品美女久久久久av超清| 久久精品夜夜夜夜夜久久| 国产成人自拍视频在线观看| 成人免费视频网| 欧美亚洲一级片| 秋霞av国产精品一区| 欧美国产日产韩国视频| 最好看的2019年中文视频| 日韩av片免费在线观看| 亚洲精品动漫久久久久| 久久精品最新地址| 国产免费一区二区三区在线能观看| 在线观看不卡av| 在线国产精品播放| 日韩欧美有码在线| 日韩av黄色在线观看| 国产精品久久久91| 日韩av毛片网| 精品国产一区二区在线| 国产精品女人久久久久久| 欧美在线一区二区三区四| 91大神福利视频在线| 欧美成人精品不卡视频在线观看| 国产精品久久久久福利| 性色av一区二区三区免费| 国内精品小视频| 久久777国产线看观看精品| 国产亚洲精品久久久优势| 欧美诱惑福利视频| 欧美麻豆久久久久久中文| 亚洲激情视频网站| 成人日韩在线电影| 91精品久久久久久久久久另类| 欧美自拍视频在线| 亚洲天堂av在线免费观看| 久久久国产精品x99av| 欧洲亚洲女同hd| 91亚洲精品一区| 亚洲精品在线91| 91国自产精品中文字幕亚洲| 日韩国产欧美精品在线| 欧美老少做受xxxx高潮| 亚洲美女久久久| 亚洲成人网在线观看| 欧美午夜片欧美片在线观看| 日韩禁在线播放| 欧美日韩国产二区| 亚洲国产欧美在线成人app| 欧美成人免费在线视频| 亚洲午夜激情免费视频| 欧美国产日韩在线| 国产91色在线|| 亚洲男人天堂手机在线| 色www亚洲国产张柏芝| 97视频免费在线看| 中日韩美女免费视频网址在线观看| 91免费在线视频| 国产精品美女主播在线观看纯欲| 久久影院模特热| 欧美疯狂性受xxxxx另类| 国产精品久久久久久久久久| 日本伊人精品一区二区三区介绍| 亚洲国产精品成人av| 欧美xxxx综合视频| 欧美尤物巨大精品爽| www.日韩.com| 91中文在线观看| 亚洲精品白浆高清久久久久久| 国产综合色香蕉精品| 91精品国产沙发| 亚洲国产中文字幕在线观看| 国产ts人妖一区二区三区|