首页
/
每日頭條
/
科技
/
學習數據結構與算法的基礎
學習數據結構與算法的基礎
更新时间:2025-03-24 09:39:24

學習數據結構與算法的基礎?摘要堆可以分為大頂堆和小頂堆,是根據節點與子節點的比較來界定文章中可以使用數組來存放元素,并處理節點與子節點的比較和交換,就是利用了二叉樹的基礎性質,看完文章相當于再次溫習了二叉樹的基礎性質,今天小編就來說說關于學習數據結構與算法的基礎?下面更多詳細答案一起來看看吧!

學習數據結構與算法的基礎(數據結構與算法-基礎)1

學習數據結構與算法的基礎

摘要

堆可以分為大頂堆和小頂堆,是根據節點與子節點的比較來界定。文章中可以使用數組來存放元素,并處理節點與子節點的比較和交換,就是利用了二叉樹的基礎性質,看完文章相當于再次溫習了二叉樹的基礎性質。

堆可以分為大頂堆和小頂堆,大頂堆的定義就是每個節點的值都大于或等于其左右子節點的值。小頂堆和大頂堆相反,即每個節點的值都小于或等于其左右子節點的值。接下來的說明以大頂堆為例。

根據大頂堆的定義可以梳理出這幾點特性:

  1. 根節點的值是最大的
  2. 節點的左右子節點沒有左子節點值必須小于右子節點值,反之也是沒有限制
  3. 節點、它的左子節點、它的右子節點這三個節點中,節點的值是最大的

接下來,咱就用數組來實現大頂堆的數據結構。為什麼要用數組而不是二叉樹來實現?帶着問題,繼續往下看,後面給出答案。

首先創建一個大頂堆的類結構,并定義數組、數量等屬性

public class BinaryHeap<E> { private E[] elements; private int size; }

假設将 elements 數組裡 index 索引中的元素放到合适的位置,這時就要考慮兩點:

  1. index 索引位置在葉子節點
  2. index 索引位置在非葉子節點

如果是情況1,那就可以不做處理,因為依據特性2來看,子節點之間沒有比較元素的要求,凡是葉子節點,都是子節點,所以葉子節點可以不用處理,等着它的父節點來主動比較。

如果是情況2,那麼就需要和它的左右子節點比較,然後和最大值的節點交換,在編寫邏輯之前,首先要确定以下幾點(假定節點的索引為 index,數組中元素的數量為 size):

  • 非葉子節點的數量 half = size >> 1(half = size / 1);
  • 節點的左子節點索引 leftIndex = (index << 1) 1;
  • 節點的右子節點索引 rightIndex = leftIndex 1;

位運算符示例:

x << 1: x *2

x >> 1: x / 2

上面這 3 點都是二叉樹的基本特性,可以看第六期再溫習一下,下面就可以編寫防治 index 索引的節點的代碼:

private void siftDown(int index) { E element = elements[index]; int half = size >> 1; // 取出非葉子節點 // 第一個葉子結點的索引 == 非葉子節點的數量 // 必須保證 index 是非葉子節點 while (index < half) { // index 的節點有2種情況 // 1、隻有左子節點 // 2、同時有左右子節點 // 默認左子節點跟它進行比較 int childIndex = (index << 1) 1; E child = elements[childIndex]; // 右子節點 int rightIndex = childIndex 1; // 保證右子節點存在(rightIndex < size),并比較左右子節點 if (rightIndex < size && compare(elements[rightIndex], child) > 0) { child = elements[ childIndex = rightIndex]; } if (compare(child, element) < 0) break; // 将子節點存放到index位置 elements[index] = child; // 重新設置 index,繼續判斷 index = childIndex; } elements[index] = element; }

看 siftDown 方法的實現邏輯,可以發現是從 index 往下過濾,尋找合适的位置,那麼有沒有從 index 往上過濾呢?上代碼:

private void siftUp(int index) { E e = elements[index]; while (index > 0) { // 得到 index 位置節點的父節點 int pIndex = (index - 1) >> 1; E p = elements[pIndex]; // 節點小于或等于它的父節點時,結束 if (compare(e, p) <= 0) break; // 交換節點元素,父節點設置為 index 節點再進行判斷 elements[index] = p; index = pIndex; } elements[index] = e; }

(index - 1) >> 1 就是獲取父節點索引代碼,也是二叉樹的基本性質。

當解決将 index 索引節點放在合适位置的核心問題之後,就可以處理後面這幾個需求了。

比如,當需要批量添加元素,即直接将一個數組處理成大頂堆時(假設元素已經放入 elements 中 ):

// 批量建堆 private void heapify() { // 自下而上的下濾,隻需要處理非葉子節點即可 for (int i = (size >> 1) - 1; i >= 0; i--) { siftDown(i); } }

如果使用 siftUp 函數來實現批量建堆,就需要從頭遍曆到最後的位置:

// 批量建堆 private void heapify() { // 自上而下的上濾 for (int i = 0; i < size; i ) { siftUp(i); } }

總結

  • 大頂堆就是每個節點都大于它的左右子節點,小頂堆剛相反;
  • 非葉子節點的數量 half = size >> 1(half = size / 1);
  • siftDown 來批量建堆時,可以減少一半的遍曆次數;
,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
李開複談騰訊企業
李開複談騰訊企業
李開複談騰訊企業?Facebook效仿蘋果開發芯片,或涉足消費設備領域,今天小編就來說說關于李開複談騰訊企業?下面更多詳細答案一起來看看吧!李開複談騰訊企業大公司Facebook效仿蘋果開發芯片,或涉足消費設備領域據彭博社援引知情人士報道,...
2025-03-24
圖文處理筆記本電腦配置推薦
圖文處理筆記本電腦配置推薦
今天我有幸目睹了一位電腦大神寫的2500元電腦配置單,客戶帶着這張大神寫的電腦配置單反反複複跟我強調一定要按配置單組裝電腦,客戶說這張電腦配置單是遠在上海的舅舅幫他寫的,舅舅在上海幹電腦行業已經近20年了,行内人都喊他舅舅為:電腦大神。聽客...
2025-03-24
歐萊雅哪款乳液好用測評
歐萊雅哪款乳液好用測評
閑來說胡話,認真做測評,大家好,我是小在。上一期我們講到了美白面膜,說了有很多的美白機理在美白面膜中不适用的。但如果是乳液的話,會不會有很大的改變呢?本期,我們就以三款美白乳為例,給大家做一個測評。注重美白的小夥伴們,注意聽啦。知識篇乳液是...
2025-03-24
變更電子駕駛證手機号碼
變更電子駕駛證手機号碼
司機朋友們你的機動車和駕駛證綁定手機号正确嗎?是否有交通違法卻未收到短信提示或從未收到交管“12123”的短信那麼建議你抓緊時間核對手機号碼啦!這!很!重!要!為進一步健全“互聯網交通管理”服務體系,深入推進公安交管“放管服”改革,提升“交...
2025-03-24
最穩的骁龍8手機
最穩的骁龍8手機
稿源:安兔兔大家9月好,歡迎收看這一期的安兔兔安卓手機性能榜榜單,8月份的又一波骁龍8Gen1新機潮過去之後,陸續再發布的新機廠商可能就要少一些了,首先是9月初的華為Mate50以及iPhone14要來,上半月的熱度很難抵擋得了。再者就是今...
2025-03-24
Copyright 2023-2025 - www.tftnews.com All Rights Reserved