成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

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

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

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

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

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

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

typedef int data_type;

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

寫一個(gè)申請根節(jié)點(diǎn)的函數(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é)點(diǎn)

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

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ī)則為【左右根】

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

前序遍歷
//前序遍歷
int preOrder(tree *pRoot)
{if(pRoot == NULL)
	{return -1;
	}
	//先訪問根結(jié)點(diǎn)
	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);
}

運(yùn)行結(jié)果

遞歸思想

拿我們的前序遍歷來講解

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

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

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

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

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

廣告

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

外貿(mào)網(wǎng)站制作
塔城市| 商河县| 密云县| 思南县| 望都县| 右玉县| 庄浪县| 贡觉县| 阳东县| 弥勒县| 固始县| 安国市| 罗田县| 调兵山市| 玉屏| 夏邑县| 阿合奇县| 叶城县| 全椒县| 凤冈县| 昌邑市| 大理市| 罗城| 隆尧县| 平湖市| 临安市| 汶上县| 遂昌县| 濮阳市| 栖霞市| 于都县| 樟树市| 承德县| 桦川县| 深水埗区| 遂昌县| 太仆寺旗| 大石桥市| 濉溪县| 罗城| 六盘水市|