欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

二叉樹的三種遍歷(雙鏈表實現(xiàn))以及遞歸思想的個人理解--C語言-創(chuàng)新互聯(lián)

文章目錄
  • 二叉樹
  • 實現(xiàn)一個數(shù)組的二叉樹插入遍歷
  • 創(chuàng)建一個二叉樹雙鏈表
  • 插入結(jié)點
  • 三種遍歷
    • 前序遍歷
    • 中序遍歷
    • 后序遍歷
    • 遞歸思想

在海拉爾等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務理念,為客戶提供做網(wǎng)站、成都網(wǎng)站建設 網(wǎng)站設計制作按需網(wǎng)站建設,公司網(wǎng)站建設,企業(yè)網(wǎng)站建設,高端網(wǎng)站設計,成都營銷網(wǎng)站建設,外貿(mào)網(wǎng)站制作,海拉爾網(wǎng)站建設費用合理。二叉樹

二叉樹(Binary tree)是樹形結(jié)構(gòu)的一個重要類型。許多實際問題抽象出來的數(shù)據(jù)結(jié)構(gòu)往往是二叉樹形式,即使是一般的樹也能簡單地轉(zhuǎn)換為二叉樹,而且二叉樹的存儲結(jié)構(gòu)及其算法都較為簡單,因此二叉樹顯得特別重要。二叉樹特點是每個節(jié)點最多只能有兩棵子樹,且有左右之分。所以實現(xiàn)二叉樹的遍歷用雙鏈表比較簡單。

實現(xiàn)一個數(shù)組的二叉樹插入遍歷
data_type arr[] = {35,45,23,44,33,65,13,54};
創(chuàng)建一個二叉樹雙鏈表

根據(jù)二叉樹的特點,我們定義一個包含左右孩子和本身數(shù)據(jù)的結(jié)構(gòu)體作為根結(jié)點

typedef int data_type;

typedef struct treeNode
{struct treeNode *lchild;
	struct treeNode *rchild;
	data_type data;
}tree;

寫一個申請根節(jié)點的函數(shù),返回申請到的空間的首地址

tree *createTree(data_type item)
{tree *pRoot = NULL;
	pRoot = (tree *)malloc(sizeof(tree));
	if(pRoot == NULL)
	{return NULL;
	}
	memset(pRoot,0,sizeof(tree));
	pRoot->data = item;

	return pRoot;
}
插入結(jié)點

插入結(jié)點時,我們要先判斷插入的值和根結(jié)點值誰更大,比根結(jié)點大我們將他插入到左孩子中,否則插入到右孩子中

int insertTree(tree *pRoot,data_type item)
{tree *pNew = NULL;
	pNew = (tree *)malloc(sizeof(tree));
	if(pNew == NULL)
	{return -1;
	}
	memset(pNew,0,sizeof(tree));
	pNew->data = item;
	while(1)
	{		if(pNew->data< pRoot->data)//插入左孩子處
		{	if(pRoot->lchild != NULL)
			{		pRoot = pRoot->lchild;
			}
			else
			{		pRoot->lchild = pNew;
				return 0;
			}
		}
		else
		{	if(pRoot->rchild != NULL)//插入右孩子處
			{		pRoot = pRoot->rchild;
			}
			else
			{		pRoot->rchild = pNew;
				return 0;
			}
		}
	}
}
三種遍歷

二叉樹的遍歷分為以下三種:

  • 先序遍歷:遍歷順序規(guī)則為【根左右】

  • 中序遍歷:遍歷順序規(guī)則為【左根右】

  • 后序遍歷:遍歷順序規(guī)則為【左右根】

利用遞歸思想,實現(xiàn)二叉樹的遍歷。會在末尾講解二叉樹的遞歸

前序遍歷
//前序遍歷
int preOrder(tree *pRoot)
{if(pRoot == NULL)
	{return -1;
	}
	//先訪問根結(jié)點
	printf("%d ",pRoot->data);
	//訪問左子樹
	preOrder(pRoot->lchild);
	//訪問右子樹
	preOrder(pRoot->rchild);
}
中序遍歷
//中序遍歷
int inOrder(tree *pRoot)
{if(pRoot == NULL)
	{return -1;
	}
	inOrder(pRoot->lchild);
	printf("%d ",pRoot->data);
	inOrder(pRoot->rchild);
}
后序遍歷
//后序遍歷
int postOrder(tree *pRoot)
{if(pRoot == NULL)
	{return -1;
	}
	postOrder(pRoot->lchild);
	postOrder(pRoot->rchild);
	printf("%d ",pRoot->data);
}

運行結(jié)果

遞歸思想

拿我們的前序遍歷來講解

if(pRoot == NULL)
	{return -1;
	}
	//先訪問根結(jié)點
	printf("%d ",pRoot->data); // 1
	//訪問左子樹
	preOrder(pRoot->lchild); // 2
	//訪問右子樹
	preOrder(pRoot->rchild); // 3

接下來用一張自己畫的圖來詳細說明
二叉樹遞歸遍歷思想
以上是我對遞歸思想的理解,如有錯誤請指正!

你是否還在尋找穩(wěn)定的海外服務器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機房具備T級流量清洗系統(tǒng)配攻擊溯源,準確流量調(diào)度確保服務器高可用性,企業(yè)級服務器適合批量采購,新人活動首月15元起,快前往官網(wǎng)查看詳情吧

網(wǎng)頁名稱:二叉樹的三種遍歷(雙鏈表實現(xiàn))以及遞歸思想的個人理解--C語言-創(chuàng)新互聯(lián)
地址分享:http://www.chinadenli.net/article22/dhcojc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版網(wǎng)站內(nèi)鏈面包屑導航網(wǎng)站排名營銷型網(wǎng)站建設網(wǎng)站策劃

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作