亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

利用go語言判斷是否是完全二叉樹

 更新時間:2022年05月17日 11:58:12   作者:??呆呆燦????  
這篇文章主要介紹了利用go語言判斷是否是完全二叉樹,當(dāng)一個節(jié)點存在右子節(jié)點但是不存在左子節(jié)點這顆樹視為非完全二叉樹,通過利用GO語言判斷來判斷出否是完全二叉樹,詳細(xì)內(nèi)容參考如下

一、什么是完全二叉樹?

先看如下這一張圖:

這個一顆二叉樹,如何區(qū)分該樹是不是完全二叉樹呢?

  • 當(dāng)一個節(jié)點存在右子節(jié)點但是不存在左子節(jié)點這顆樹視為非完全二叉樹
  • 當(dāng)一個節(jié)點的左子節(jié)點存在但是右子節(jié)點不存在視為完全二叉樹
  • 如果沒有子節(jié)點,那也是要在左側(cè)開始到右側(cè)依次沒有子節(jié)點才視為完全二叉樹,就像上圖2中

而上面第一張圖這顆二叉樹很明顯是一顆非完全二叉樹,因為在第三層也就是在節(jié)點2它并沒有右子節(jié)點。在6和4節(jié)點中隔開了一個節(jié)點(2節(jié)點沒有右子節(jié)點),所以不是完全二叉樹

再看第二張圖,這顆樹就是一個完全二叉樹,雖然在這個顆節(jié)點3沒有右子節(jié)點,但是6 4 5節(jié)點之間并沒有空缺的子節(jié)點,這里就解釋了上面說的第三條(如何沒有子節(jié)點,那也是在左側(cè)開始到右側(cè)依次沒有子節(jié)點才視為完全二叉樹)

二、流程

這道題可以使用按層遍歷的方式來解決:

  • 首先準(zhǔn)備一個隊列,按層遍歷使用隊列是最好的一種解決方法
  • 首先將頭節(jié)點加入到隊列里面(如果頭節(jié)點為空,你可以認(rèn)為它是一個非完全二叉樹也可以認(rèn)為它是完全二叉樹)
  • 遍歷該隊列跳出遍歷的條件是直到這個隊列為空時
  • 這個時候需要準(zhǔn)備一個Bool的變量,如果當(dāng)一個節(jié)點的左子節(jié)點或者右子節(jié)點不存在時將其置成true
  • 當(dāng)Bool變量為true并且剩余節(jié)點的左或右子節(jié)點不為空該樹就是非完全二叉樹
  • 當(dāng)一樹的左子節(jié)點不存在并且右子節(jié)點存在,該樹也是非完全二叉樹

三、代碼

1.樹節(jié)點

type TreeNode struct {
	val   string
	left  *TreeNode
	right *TreeNode
}

2.測試代碼

func main() {
	root := &TreeNode{val: "1"}
	root.left = &TreeNode{val: "2"}
	root.left.left = &TreeNode{val: "4"}
	root.left.right = &TreeNode{val: "10"}
	root.left.left.left = &TreeNode{val: "7"}
	root.right = &TreeNode{val: "3"}
	root.right.left = &TreeNode{val: "5"}
	root.right.right = &TreeNode{val: "6"}
	if IsCompleteBt(root) {
		fmt.Println("是完全二叉樹")
	} else {
		fmt.Println("不是完全二叉樹")
	}
}

3.判斷樹是否為完全二叉樹代碼

// IsCompleteBt 這里默認(rèn)根節(jié)點為空屬于完全二叉樹,這個可以自已定義是否為完全二叉樹/***/
func IsCompleteBt(root *TreeNode) bool {
	if root == nil {
		return true
	}

	/**
	* 條件:
	* 	1.當(dāng)一個節(jié)點存在右子節(jié)點但是不存在左子節(jié)點這顆樹視為非完全二叉樹
	*	2.當(dāng)一個節(jié)點的左子節(jié)點存在但是右子節(jié)點不存在視為完全二叉樹
	 */
	var tempNodeQueue []*TreeNode

	tempNodeQueue = append(tempNodeQueue, root)

	var tempNode *TreeNode
	isSingleNode := false
	for len(tempNodeQueue) != 0 {
		tempNode = tempNodeQueue[0]
		tempNodeQueue = tempNodeQueue[1:]

		if (isSingleNode && (tempNode.left != nil || tempNode.right != nil)) || (tempNode.left == nil && tempNode.right != nil){
			return false
		}

		if tempNode.left != nil{
			tempNodeQueue = append(tempNodeQueue,tempNode.left)
		}else{
			isSingleNode = true
		}

		if  tempNode.right != nil {
			tempNodeQueue = append(tempNodeQueue, tempNode.right)
		}else{
			isSingleNode = true
		}
	}
	return true
}

4.代碼解讀

這段代碼里面沒有多少好說的,就說下for里面第一個if判斷叭

這里看下上面流程中最后兩個條件,當(dāng)滿足最后兩個條件的時候才可以判斷出來這顆樹是否是完全二叉樹.

同樣因為實現(xiàn)判斷是否是完全二叉樹是通過對樹的按層遍歷來處理的,因為對樹的按層遍歷通過隊列是可以間單的實現(xiàn)的。所以這里使用到了隊列

至于這里為什么要單獨(dú)創(chuàng)建一個isSingleNode變量:

  • 因為當(dāng)有一個節(jié)點左側(cè)節(jié)點或者是右側(cè)的節(jié)點沒有的時候,在這同一層后面如果還有不為空的節(jié)點時,那么這顆樹便不是完全二叉樹,看下圖

在這顆樹的最后一層綠色涂鴨處是少一個節(jié)點的,所以我用了一個變量我標(biāo)識當(dāng)前節(jié)點(在上圖表示節(jié)點2)的子節(jié)點是不是少一個,如果少了當(dāng)前節(jié)點(在上圖表示節(jié)點2)的下一個節(jié)點(在上圖表示節(jié)點3)的子節(jié)點(在上圖表示4和5)如果存在則不是完全二叉樹,所以這就是創(chuàng)建了一個isSingleNode變量的作用

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

到此這篇關(guān)于利用go語言判斷是否是完全二叉樹的文章就介紹到這了,更多相關(guān)go 二叉樹內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Golang中fsnotify包監(jiān)聽文件變化的原理詳解

    Golang中fsnotify包監(jiān)聽文件變化的原理詳解

    Golang提供了一個強(qiáng)大的fsnotify包,它能夠幫助我們輕松實現(xiàn)文件系統(tǒng)的監(jiān)控,本文將深入探討fsnotify包的原理,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-12-12
  • Go singleflight使用以及原理

    Go singleflight使用以及原理

    singleflight官方解釋其為:singleflight提供了一個重復(fù)的函數(shù)調(diào)用抑制機(jī)制。通俗的解釋其作用是,若有多個協(xié)程運(yùn)行某函數(shù)時,只讓一個協(xié)程去處理,然后批量返回。非常適合來做并發(fā)控制。常見用于緩存穿透的情況
    2023-01-01
  • Golang 獲取文件md5校驗的方法以及效率對比

    Golang 獲取文件md5校驗的方法以及效率對比

    這篇文章主要介紹了Golang 獲取文件md5校驗的方法以及效率對比,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-05-05
  • 一百行Golang代碼實現(xiàn)簡單并發(fā)聊天室

    一百行Golang代碼實現(xiàn)簡單并發(fā)聊天室

    這篇文章主要為大家詳細(xì)介紹了一百行Golang代碼如何實現(xiàn)簡單并發(fā)聊天室,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • Golang學(xué)習(xí)筆記(六):struct

    Golang學(xué)習(xí)筆記(六):struct

    這篇文章主要介紹了Golang學(xué)習(xí)筆記(六):struct,本文講解了struct的聲明及初始化、struct的匿名字段(繼承)、method、method繼承和重寫等內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • GO語言實現(xiàn)二維碼掃碼的示例代碼

    GO語言實現(xiàn)二維碼掃碼的示例代碼

    你對二維碼掃碼的流程有困惑嗎,這篇文章就結(jié)合筆者自身的開發(fā)經(jīng)驗進(jìn)行分享,讓大家熟悉并掌握此功能,感興趣的小伙伴快跟隨小編一起學(xué)習(xí)一下吧
    2023-06-06
  • go語言通過odbc操作Access數(shù)據(jù)庫的方法

    go語言通過odbc操作Access數(shù)據(jù)庫的方法

    這篇文章主要介紹了go語言通過odbc操作Access數(shù)據(jù)庫的方法,實例分析了Go語言通過odbc連接、查詢與關(guān)閉access數(shù)據(jù)庫的技巧,需要的朋友可以參考下
    2015-03-03
  • mac下安裝golang框架iris的方法

    mac下安裝golang框架iris的方法

    這篇文章主要介紹了mac下安裝golang框架iris的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • Go語言kafka生產(chǎn)消費(fèi)消息實例搬磚

    Go語言kafka生產(chǎn)消費(fèi)消息實例搬磚

    這篇文章主要為大家介紹了Go語言kafka生產(chǎn)消費(fèi)消息的實例搬磚,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • Go中過濾范型集合性能示例詳解

    Go中過濾范型集合性能示例詳解

    這篇文章主要為大家介紹了Go中過濾范型集合性能示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03

最新評論