搜尋
首頁後端開發php教程PHP資料結構:堆資料結構的奧妙,實現高效率的排序與優先權佇列

PHP 中的堆資料結構是一種滿足完全二元樹和堆性質(父結點值大於/小於子結點值)的樹狀結構,使用陣列實現。堆支援兩種操作:排序(從小到大提取最大元素)和優先權隊列(根據優先權提取最大元素),分別透過 heapifyUp 和 heapifyDown 方法維護堆的性質。

PHP資料結構:堆資料結構的奧妙,實現高效率的排序與優先權佇列

PHP 中的堆疊資料結構:揭秘排序與優先權佇列的奧秘

堆疊是一種樹狀資料結構,它滿足以下兩個性質:

  • 完全二元樹性質:樹中的每個結點都有兩個子結點,或沒有子結點,形成一棵完全二元樹。
  • 堆性質:每個父結點的值都大於(或等於)它的兩個子結點的值(最大堆)或小於(或等於)它的兩個子結點的值(最小堆)。

PHP 實作

在 PHP 中,我們使用陣列來實作堆疊。以下是一個最大堆的PHP 實作:

class MaxHeap {
    private $heap = array();
    private $size = 0;

    public function insert($value) {
        $this->heap[$this->size++] = $value;
        $this->heapifyUp($this->size - 1);
    }

    private function heapifyUp($index) {
        if ($index === 0) {
            return;
        }
        $parentIndex = intval(($index - 1) / 2);
        if ($this->heap[$index] > $this->heap[$parentIndex]) {
            $temp = $this->heap[$index];
            $this->heap[$index] = $this->heap[$parentIndex];
            $this->heap[$parentIndex] = $temp;
            $this->heapifyUp($parentIndex);
        }
    }

    public function extractMax() {
        if ($this->size === 0) {
            return null;
        }
        $max = $this->heap[0];
        $this->heap[0] = $this->heap[$this->size - 1];
        $this->size--;
        $this->heapifyDown(0);
        return $max;
    }

    private function heapifyDown($index) {
        $largestIndex = $index;
        $leftIndex = 2 * $index + 1;
        $rightIndex = 2 * $index + 2;
        if ($leftIndex < $this->size && $this->heap[$leftIndex] > $this->heap[$largestIndex]) {
            $largestIndex = $leftIndex;
        }
        if ($rightIndex < $this->size && $this->heap[$rightIndex] > $this->heap[$largestIndex]) {
            $largestIndex = $rightIndex;
        }
        if ($largestIndex !== $index) {
            $temp = $this->heap[$index];
            $this->heap[$index] = $this->heap[$largestIndex];
            $this->heap[$largestIndex] = $temp;
            $this->heapifyDown($largestIndex);
        }
    }
}

實戰案例

排序:

$heap = new MaxHeap();
$heap->insert(10);
$heap->insert(5);
$heap->insert(15);
$heap->insert(8);
$heap->insert(12);

while ($heap->size > 0) {
    echo $heap->extractMax() . " ";
}

輸出:15 12 10 8 5

優先權佇列:

$heap = new MaxHeap();
$heap->insert(5);
$heap->insert(2);
$heap->insert(3);
$heap->insert(1);

while ($heap->size > 0) {
    $element = $heap->extractMax();
    echo "服务于元素 " . $element . "\n";
}

輸出:
服務於元素5
服務於元素3
服務於元素2
服務於元素1

以上是PHP資料結構:堆資料結構的奧妙,實現高效率的排序與優先權佇列的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
heap和stack有什么区别heap和stack有什么区别Nov 22, 2022 pm 04:12 PM

区别:1、堆(heap)的空间一般由程序员分配释放;而栈(stack)的空间由操作系统自动分配释放 。2、heap是存放在二级缓存中,生命周期由虚拟机的垃圾回收算法来决定;而stack使用的是一级缓存,通常都是被调用时处于存储空间中,调用完毕立即释放。3、数据结构不同,heap可以被看成是一棵树,而stack是一种先进后出的数据结构。

Python中的Deque: 实现高效的队列和堆栈Python中的Deque: 实现高效的队列和堆栈Apr 12, 2023 pm 09:46 PM

Python 中的 deque 是一个低级别的、高度优化的双端队列,对于实现优雅、高效的Pythonic 队列和堆栈很有用,它们是计算中最常见的列表式数据类型。本文中,云朵君将和大家一起学习如下:开始使用deque有效地弹出和追加元素访问deque中的任意元素用deque构建高效队列开始使用Deque向 Python 列表的右端追加元素和弹出元素的操作,一般非常高效。如果用大 O 表示时间复杂性,那么可以说它们是 O(1)。而当 Python 需要重新分配内存来增加底层列表以接受新的元素时,这些

堆和栈的区别堆和栈的区别Jul 18, 2023 am 10:17 AM

堆和栈的区别:1、内存分配方式不同,堆是由程序员手动分配和释放的,而栈是由操作系统自动分配和释放的;2、大小不同,栈的大小是固定的,而堆的大小是动态增长的;3、数据访问方式不同,在堆中,数据的访问是通过指针来实现的,而在栈中,数据的访问是通过变量名来实现的;4、数据的生命周期,在堆中,数据的生命周期可以很长,而在栈中,变量的生命周期是由其所在的作用域来决定的。

java堆和栈有哪些区别java堆和栈有哪些区别Dec 25, 2023 pm 05:29 PM

java堆和栈的区别:1、内存分配和管理;2、存储内容;3、线程执行和生命周期;4、性能影响。详细介绍:1、内存分配和管理,Java堆是动态分配的内存区域,主要用来存储对象实例,在Java中,对象是通过堆内存进行分配的,当创建一个对象时,Java虚拟机会在堆上分配相应的内存空间,并自动进行垃圾回收和内存管理,堆的大小可以在运行时动态调整,通过JVM参数进行配置等等。

C++中的堆和优先队列C++中的堆和优先队列Aug 22, 2023 pm 04:16 PM

堆和优先队列是C++中常用的数据结构,它们都具有重要的应用价值。本文将分别对堆和优先队列进行介绍和解析,帮助读者更好地理解和使用它们。一、堆堆是一种特殊的树形数据结构,它可以用来实现优先队列。在堆中,每个节点都满足如下性质:它的值不小于(或不大于)其父节点的值。它的左右子树也是一个堆。我们将不小于其父节点的堆称为“最小堆”,将不大于其父节点的堆称为“最大堆”

PHP数据结构:堆数据结构的奥妙,实现高效的排序与优先级队列PHP数据结构:堆数据结构的奥妙,实现高效的排序与优先级队列Jun 01, 2024 pm 03:54 PM

PHP中的堆数据结构是一种满足完全二叉树和堆性质(父结点值大于/小于子结点值)的树状结构,使用数组实现。堆支持两种操作:排序(从小到大提取最大元素)和优先级队列(根据优先级提取最大元素),分别通过heapifyUp和heapifyDown方法维护堆的性质。

Python中的堆和优先队列的使用场景有哪些?Python中的堆和优先队列的使用场景有哪些?Oct 28, 2023 am 08:56 AM

Python中的堆和优先队列的使用场景有哪些?堆是一种特殊的二叉树结构,常用于高效地维护一个动态的集合。Python中的heapq模块提供了堆的实现,可以方便地进行堆的操作。优先队列也是一种特殊的数据结构,不同于普通的队列,它的每个元素都有一个与之相关的优先级。最高优先级的元素先被取出。Python中的heapq模块也可以实现优先队列的功能。下面我们介绍一些

Go语言中的堆、栈、字典、红黑树等数据结构Go语言中的堆、栈、字典、红黑树等数据结构Jun 03, 2023 pm 03:10 PM

随着计算机科学的发展,数据结构成为了一门重要的学科。在软件开发中,数据结构是非常重要的,它们可以提高程序效率和可读性,同时也可以帮助解决各种问题。在Go语言中,堆、栈、字典、红黑树等数据结构也是非常重要的。本文将介绍这些数据结构及其在Go语言中的实现。堆堆(Heap)是一个经典的数据结构,用来解决优先队列问题。优先队列指的是一种队列,在取出元素的时候,按照元

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器