$74 GRAYBYTE WORDPRESS FILE MANAGER $64

SERVER : premium201.web-hosting.com #1 SMP Wed Mar 26 12:08:09 UTC 2025
SERVER IP : 172.67.217.254 | ADMIN IP 216.73.216.180
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : mail

/opt/alt/php84/usr/include/php/ext/swoole/include/

HOME
Current File : /opt/alt/php84/usr/include/php/ext/swoole/include//swoole_heap.h
/*
 +----------------------------------------------------------------------+
 | Swoole                                                               |
 +----------------------------------------------------------------------+
 | This source file is subject to version 2.0 of the Apache license,    |
 | that is bundled with this package in the file LICENSE, and is        |
 | available through the world-wide-web at the following url:           |
 | http://www.apache.org/licenses/LICENSE-2.0.html                      |
 | If you did not receive a copy of the Apache2.0 license and are unable|
 | to obtain it through the world-wide-web, please send a note to       |
 | [email protected] so we can mail you a copy immediately.               |
 +----------------------------------------------------------------------+
 | Author: Tianfeng Han  <[email protected]>                             |
 +----------------------------------------------------------------------+
 */

#pragma once

namespace swoole {

struct HeapNode {
    uint64_t priority;
    uint32_t position;
    void *data;
};

class Heap {
 public:
    enum Type {
        MIN_HEAP,
        MAX_HEAP,
    };

    Heap(size_t _n, Type _type);
    ~Heap();

    size_t count() {
        return num - 1;
    }

    HeapNode *push(uint64_t priority, void *data);
    void *pop();
    void change_priority(uint64_t new_priority, HeapNode *ptr);
    void remove(HeapNode *node);
    void *peek();
    void print();
    int compare(uint64_t a, uint64_t b);

    HeapNode *top() {
        if (num == 1) {
            return nullptr;
        }
        return nodes[1];
    }

 private:
    uint32_t num;
    uint32_t size;
    enum Type type;
    HeapNode **nodes;

    void bubble_up(uint32_t i);
    uint32_t maxchild(uint32_t i);
    void percolate_down(uint32_t i);
};
}



Current_dir [ NOT WRITEABLE ] Document_root [ NOT WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
1 Jan 1970 12.00 AM
root / root
0
swoole.h
24.834 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_api.h
3.429 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_asm_context.h
2.281 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_async.h
3.611 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_atomic.h
3.717 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_base64.h
1.294 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_buffer.h
2.233 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_c_api.h
2.076 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_channel.h
2.337 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_client.h
8.646 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_config.h
8.877 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_coroutine.h
9.975 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_coroutine_c_api.h
5.825 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_coroutine_channel.h
4.184 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_coroutine_context.h
2.747 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_coroutine_socket.h
18.781 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_coroutine_system.h
3.867 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_dtls.h
2.405 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_error.h
6.108 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_file.h
4.43 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_file_hook.h
3.837 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_hash.h
9.69 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_heap.h
1.785 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_http.h
6.989 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_http2.h
8.383 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_iouring.h
3.098 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_lock.h
3.39 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_log.h
15.337 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_lru_cache.h
3.169 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_memory.h
2.747 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_message_bus.h
6.024 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_mime_type.h
1.441 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_mqtt.h
2.176 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_msg_queue.h
1.924 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_pipe.h
2.637 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_process_pool.h
9.938 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_protocol.h
5.167 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_proxy.h
2.873 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_reactor.h
11.249 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_redis.h
2.092 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_server.h
43.944 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_signal.h
1.721 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_socket.h
19.039 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_socket_hook.h
2.23 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_ssl.h
4.943 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_static_handler.h
4.702 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_string.h
8.869 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_table.h
7.346 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_thread.h
2.227 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_timer.h
4.127 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_util.h
6.606 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_version.h
2.211 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_websocket.h
4.529 KB
12 Mar 2025 2.32 PM
root / linksafe
0644
swoole_wheel_timer.h
2.479 KB
12 Mar 2025 2.32 PM
root / linksafe
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025 CONTACT ME
Static GIF