欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java編程求二叉樹的鏡像兩種方法介紹

 更新時(shí)間:2017年11月20日 11:48:32   作者:HankingHu  
這篇文章主要介紹了Java編程求二叉樹的鏡像兩種方法介紹,分享了兩種方法,遞歸與非遞歸,每種方法又分別介紹了兩種解決思路,具有一定參考價(jià)值,需要的朋友可以了解下。

給出一棵二叉樹,求它的鏡像,如下圖:右邊是二叉樹是左邊二叉樹的鏡像。

仔細(xì)分析這兩棵樹的特點(diǎn),看看能不能總結(jié)出求鏡像的步驟。這兩棵樹的根節(jié)點(diǎn)相同,但他們的左右兩個(gè)子節(jié)點(diǎn)交換了位置。因此我們不妨先在樹中交換根節(jié)點(diǎn)的兩個(gè)子節(jié)點(diǎn),就得到了下面一幅圖中的第二顆樹

解法1(遞歸)

思路1:如果當(dāng)前節(jié)點(diǎn)為空,返回,否則交換該節(jié)點(diǎn)的左右節(jié)點(diǎn),遞歸的對(duì)其左右節(jié)點(diǎn)進(jìn)行交換處理。

/*class TreeNode{
  int val;
  TreeNode left=null; 
  TreeNode right=null;
  public TreeNode(int val) {
    this.val = val;
  }
}*/
public static void mirrorTree(TreeNode root)
  {
	if(root==null)
	      return;
	//交換該節(jié)點(diǎn)指向的左右節(jié)點(diǎn)。
	TreeNode temp=root.left;
	root.left=root.right;
	root.right=temp;
	//對(duì)其左右孩子進(jìn)行鏡像處理。
	mirrorTree(root.left);
	mirrorTree(root.right);
}

交換過程如下圖:

交換根節(jié)點(diǎn)的兩個(gè)子節(jié)點(diǎn)之后,我們注意到值為10,6的結(jié)點(diǎn)的子節(jié)點(diǎn)仍然保持不變,因此我們還需要交換這兩個(gè)結(jié)點(diǎn)的左右子節(jié)點(diǎn)。交換之后的結(jié)果分別為第三課樹和第四顆樹。做完這兩次交換之后,我們已經(jīng)遍歷完所有的非葉子結(jié)點(diǎn)。此時(shí)交換之后的樹剛好就是原始樹的鏡像。

思路2:如果當(dāng)前節(jié)點(diǎn)為 null,返回 null ,否則先分別對(duì)該節(jié)點(diǎn)的左右孩子進(jìn)行鏡像處理,然后將該節(jié)點(diǎn)的左指針指向右孩子,右指針指向左孩子,對(duì)該節(jié)點(diǎn)進(jìn)行鏡像處理。

/*class TreeNode{
  int val;
  TreeNode left=null; 
  TreeNode right=null;
  public TreeNode(int val) {
    this.val = val;
  }
}*/
public static TreeNode mirrorTree1(TreeNode root)
  {
	if(root==null)
	      return null;
	//對(duì)左右孩子鏡像處理
	TreeNode left=mirrorTree1(root.left);
	TreeNode right=mirrorTree1(root.right);
	//對(duì)當(dāng)前節(jié)點(diǎn)進(jìn)行鏡像處理。
	root.left=right;
	root.right=left;
	return root;
}

解法2(非遞歸)

思路1:層次遍歷,根節(jié)點(diǎn)不為 null 將根節(jié)點(diǎn)入隊(duì),判斷隊(duì)不為空時(shí),節(jié)點(diǎn)出隊(duì),交換該節(jié)點(diǎn)的左右孩子,如果左右孩子不為空,將左右孩子入隊(duì)。

public static void mirrorTreeWithQueue(TreeNode root)
  {
	if(root==null)
	      return;
	//如果樹為 null 直接返回。否則將根節(jié)點(diǎn)入隊(duì)列。
	Queue<TreeNode> queue= new LinkedList<TreeNode>() ;
	queue.add(root);
	while(!queue.isEmpty())
	    {
		//隊(duì)列不為空時(shí),節(jié)點(diǎn)出隊(duì),交換該節(jié)點(diǎn)的左右子樹。
		TreeNode root1=queue.poll();
		/*TreeNode left,right;
      left=root1.left;
      right=root1.right;
      root1.right=left;
      root1.left=right;
      */
		Swap(root);
		if(root1.right!=null)
		      {
			queue.add(root1.right);
			//如果左子樹不為 null 入隊(duì)
		}
		if(root1.left!=null)
		      {
			queue.add(root1.left);
			//如果右子樹不為 null 入隊(duì)。
		}
	}
}
public static void Swap(TreeNode root)
  {
	TreeNode temp;
	temp=root.right;
	root.right=root.left;
	root.left=temp;
}

思路2:先序遍歷,如果根節(jié)點(diǎn)不為 null 將根節(jié)點(diǎn)入棧,當(dāng)棧不為 null 出棧,交換左右節(jié)點(diǎn),如果左右節(jié)點(diǎn)不為 null 入棧。

public static void mirrorTreeWithStack(TreeNode root)
  {
	if(root==null)
	      return;
	Stack<TreeNode> stack=new Stack<TreeNode>();
	stack.push(root);
	while(!stack.isEmpty())
	    {
		//當(dāng)棧不為 null 時(shí)出棧,交換左右子樹。
		TreeNode root1=stack.pop();
		/*TreeNode left,right;
      left=root1.left;
      right=root1.right;
      root1.right=left;
      root1.left=right;*/
		Swap(root);
		if(root1.right!=null)
		      {
			//右子樹不為 null 入棧
			stack.push(root1.right);
		}
		if(root1.left!=null)
		      {
			//左子樹不為 null 入棧
			stack.push(root1.left);
		}
	}
}
public static void Swap(TreeNode root)
  {
	TreeNode temp;
	temp=root.right;
	root.right=root.left;
	root.left=temp;
}

總結(jié)

以上就是本文關(guān)于Java編程求二叉樹的鏡像兩種方法介紹的全部內(nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:

java算法實(shí)現(xiàn)紅黑樹完整代碼示例

Java 蒙特卡洛算法求圓周率近似值實(shí)例詳解

java實(shí)現(xiàn)的各種排序算法代碼示例

如有不足之處,歡迎留言指出。

相關(guān)文章

  • spring boot 集成shiro的配置方法

    spring boot 集成shiro的配置方法

    要在spring boot上集成其他框架,首先要會(huì)spring javaconfig方法,利用此方法同樣可以配置其他模塊。這篇文章主要介紹了spring boot 集成shiro的配置方法,需要的朋友可以參考下
    2018-01-01
  • Java線程池submit阻塞獲取結(jié)果的實(shí)現(xiàn)原理詳解

    Java線程池submit阻塞獲取結(jié)果的實(shí)現(xiàn)原理詳解

    Java線程池中提交任務(wù)運(yùn)行,通常使用execute()方法就足夠了。那如果想要實(shí)現(xiàn)在主線程中阻塞獲取線程池任務(wù)運(yùn)行的結(jié)果,該怎么辦呢?本文就來和大家一起討論討論
    2022-10-10
  • ActiveMQ消息隊(duì)列技術(shù)融合Spring過程解析

    ActiveMQ消息隊(duì)列技術(shù)融合Spring過程解析

    這篇文章主要介紹了ActiveMQ消息隊(duì)列技術(shù)融合Spring過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • Java import導(dǎo)入及訪問控制權(quán)限修飾符原理解析

    Java import導(dǎo)入及訪問控制權(quán)限修飾符原理解析

    這篇文章主要介紹了Java import導(dǎo)入及訪問控制權(quán)限修飾符過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • SpringBoot的自動(dòng)配置原理解析

    SpringBoot的自動(dòng)配置原理解析

    這篇文章主要介紹了SpringBoot的自動(dòng)配置原理解析,SpringBoot的自動(dòng)配置要從它的啟動(dòng)類@SpringBootApplication說起,點(diǎn)進(jìn)注解,@Target設(shè)置當(dāng)前注解可以標(biāo)記在哪,(ElementType.type)表示標(biāo)注在類上面,需要的朋友可以參考下
    2023-08-08
  • IDEA調(diào)試技巧條件斷點(diǎn)實(shí)現(xiàn)步驟詳解

    IDEA調(diào)試技巧條件斷點(diǎn)實(shí)現(xiàn)步驟詳解

    這篇文章主要介紹了IDEA調(diào)試技巧條件斷點(diǎn)實(shí)現(xiàn)步驟詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • 簡單了解SpringCloud運(yùn)行原理

    簡單了解SpringCloud運(yùn)行原理

    這篇文章主要介紹了簡單了解SpringCloud運(yùn)行原理,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • springboot冪等切片的實(shí)現(xiàn)

    springboot冪等切片的實(shí)現(xiàn)

    本文主要介紹了springboot冪等切片的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Spring boot從安裝到交互功能實(shí)現(xiàn)零基礎(chǔ)全程詳解

    Spring boot從安裝到交互功能實(shí)現(xiàn)零基礎(chǔ)全程詳解

    這篇文章主要介紹了Spring boot從安裝到交互功能得實(shí)現(xiàn)全程詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • java繼承中的構(gòu)造方法實(shí)例解析

    java繼承中的構(gòu)造方法實(shí)例解析

    這篇文章主要介紹了java繼承中的構(gòu)造方法實(shí)例解析,針對(duì)繼承中的構(gòu)造方法的特點(diǎn)進(jìn)行了實(shí)例分析,需要的朋友可以參考下
    2014-10-10

最新評(píng)論