PHP
PHP

Trang chủ

Tìm hiểu về hàm Ds\PriorityQueue::peek() trong PHP

PHP, viết tắt của Hypertext Preprocessor, là ngôn ngữ lập trình script phía máy chủ được thiết kế đặc biệt cho phát triển web. Điểm nổi bật của PHP so với các ngôn ngữ khác là khả năng tương thích với nhiều loại cơ sở dữ liệu và chạy mượt mà trên các máy chủ web. Tại Vietnix, chúng tôi không chỉ giới thiệu những khái niệm cơ bản về PHP mà còn cung cấp các ví dụ thực tế giúp bạn dễ dàng hiểu và áp dụng PHP vào việc phát triển website. Bên cạnh đó, Vietnix cũng thường xuyên cập nhật các bài viết mới về tính năng, mẹo và thủ thuật lập trình, giúp bạn giải quyết các thách thức phức tạp, từ đó không ngừng nâng cao và hoàn thiện kỹ năng lập trình của mình.
html
CSS
javascript
sql
python
php
c
c++
bootstrap
react
mysql
reactjs
vuejs
Javascript Tutorials
12/07/2024
6 phút đọc
Theo dõi Vietnix trên

Tìm hiểu về hàm Ds\PriorityQueue::peek() trong PHP

Hàm Ds\PriorityQueue::peek() trong PHP được sử dụng để nhìn vào phần tử đầu tiên (phần tử có độ ưu tiên cao nhất) của Hàng đợi ưu tiên mà không loại bỏ nó. Khi bạn muốn biết giá trị của phần tử tiếp theo mà không làm thay đổi cấu trúc của Hàng đợi, hàm này là lựa chọn lý tưởng. Hãy cùng Vietnix tham khảo thêm về hàm Ds\PriorityQueue::peek() trong PHP qua bài viết sau đây.

Hàm Ds\PriorityQueue::peek() là gì?

Hàm Ds\PriorityQueue::peek() trong PHP được sử dụng để lấy giá trị hiện diện ở phía trước PriorityQueue. Ví dụ, nếu người dùng đang quản lý một danh sách các công việc theo độ ưu tiên và muốn xem công việc nào sẽ được thực hiện tiếp theo mà không thay đổi thứ tự của chúng, bạn có thể sử dụng hàm peek() để kiểm tra giá trị của công việc có độ ưu tiên cao nhất mà không làm mất đi sự ưu tiên của nó trong Hàng đợi.

Hàm Ds\PriorityQueue::peek() trong PHP
Hàm Ds\PriorityQueue::peek() được sử dụng để lấy giá trị hiện diện ở phía trước
Cú phápmixed public Ds\PriorityQueue::peek ( void )
Tham sốHàm này không chấp nhận bất kỳ tham số nào.
Giá trị trả vềHàm này trả về giá trị có ở phía trước PriorityQueue này. Kiểu trả về của hàm được trộn lẫn và phụ thuộc vào loại giá trị được lưu trữ trong PriorityQueue.
Hàm Ds\PriorityQueue::peek() trong PHP

Mọi người cũng xem:

Ví dụ minh hoạ hàm Ds\PriorityQueue::peek() trong PHP

Lưu ý: Một số công cụ dự án có thể không có hoặc không hỗ trợ thư viện/class ds trong PHP, người dùng có thể cân nhắc xây dựng một class ds của riêng mình thay thế tạm thời cho mục đích kiểm thử, nghiên cứu.

Có thể ví dụ như sau:

class SimplePriorityQueue {
    private $queue;
    private $capacity;

    public function __construct() {
        $this->queue = [];
        $this->capacity = 16;
    }

    public function push($value, $priority) {
        $this->queue[] = ['value' => $value, 'priority' => $priority];
        usort($this->queue, function ($a, $b) {
            return $b['priority'] <=> $a['priority'];
        });
    }

    public function pop() {
        if ($this->isEmpty()) {
            throw new UnderflowException("Queue is empty");
        }
        return array_shift($this->queue)['value'];
    }

    public function peek() {
        if ($this->isEmpty()) {
            throw new UnderflowException("Queue is empty");
        }
        return $this->queue[0]['value'];
    }

    public function isEmpty() {
        return empty($this->queue);
    }

    public function count() {
        return count($this->queue);
    }
    
    public function copy() {
        $copyQueue = new SimplePriorityQueue();
        foreach ($this->queue as $item) {
            $copyQueue->push($item['value'], $item['priority']);
        }
        return $copyQueue;
    }
    
    public function clear() {
        $this->queue = [];
    }
    
    public function allocate($additionalCapacity) {
        $this->capacity += $additionalCapacity;
    }

    public function capacity() {
        return $this->capacity;
    }

    public function toArray() {
        $result = [];
        foreach ($this->queue as $item) {
            $result[] = $item['value'];
        }
        return $result;
    }
}

Triển khai thành chương trình:

<?php
// insert your handmade ds class from here
$pq = new SimplePriorityQueue();

$pq->push("Vietnix", 1); 
$pq->push("Hosting", 2); 
$pq->push("VPS", 3); 

echo "PriorityQueue is: \n"; 
print_r($pq); 
  
// Get element at the front 
echo "\nElement at front is: " . $pq->peek() . PHP_EOL; 

?>

Output như sau:

PriorityQueue is: SimplePriorityQueue Object 
( 
    [queue:SimplePriorityQueue:private] => Array 
    ( 
        [0] => Array 
        ( 
            [value] => VPS 
            [priority] => 3 
        ) 
        [1] => Array 
        ( 
            [value] => Hosting 
            [priority] => 2 
        ) 
        [2] => Array 
        ( 
            [value] => Vietnix 
            [priority] => 1 
        ) 
    )
    [capacity:SimplePriorityQueue:private] => 16 
) 
Element at front is: VPS

Ví dụ 2: Nếu bạn không thêm giá trị vào hàng chờ, chương trình sẽ có dòng báo lỗi fatal sau đó.

<?php
$pq = new SimplePriorityQueue();
// insert your handmade ds class from here

echo "PriorityQueue is: \n"; 
print_r($pq); 
  
// Get element at the front 
echo "\nElement at front is: " . $pq->peek() . PHP_EOL; 

?>

Output như sau:

PriorityQueue is: SimplePriorityQueue Object 
( 
    [queue:SimplePriorityQueue:private] => Array ( ) 
    [capacity:SimplePriorityQueue:private] => 16 
)
Fatal error: Uncaught UnderflowException: Queue is empty

Lời kết

Vietnix hy vọng nội dung bài viết trên đã giúp bạn hiểu rõ hơn về hàm Ds\PriorityQueue::peek() trong PHP. Ngoài ra, bạn cũng có thể tham khảo thêm các bài viết khác tại vietnix.vn để hiểu hơn về lập trình, chúc bạn thành công!

Cao Lê Viết Tiến

PHP Leader
tại
Vietnix

Kết nối với mình qua

Icon Quote
Icon Quote

Học lập trình online cùng vietnix

Học lập trình online cùng Vietnix

PHPXem thêmThu gọn