【学习记录】AVL树及相关链表,线程池实现

本来打算使用avl树套链表的结构,来避免优先级相等的情况,但是最后发现当绝大多数优先级都相等,avl树还是不可避免的退化成单链表,而需求中也确实是绝大多数都是优先级相等。
所以评估之后觉得avl树带来的提升远不及其提升的复杂度,所以放弃该方案,改为链表实现,现将此前实验的代码整理如下,
AVL树部分应该没有问题。重要步骤做了注释
.c文件如下

//
// Created by Administrator on 2025/2/10.
//
#ifdef __cplusplus
extern "C" {
   
   
#endif
#include "threadpool.h"
#include <malloc.h>
#include <pthread.h>
#include "string.h"
///---------------------------链表操作----------------

/**
 * @brief 比较两个节点的数据
 * @param 数据1
 * @param 数据2
 * @return 0-相等 -1-不相等
 * */
int compare_node(Task_t target1,Task_t target2){
   
   
    return (target1.func == target2.func)&&(strncmp(target1.task_name,target2.task_name,strlen(target2.task_name))==0)&&(target1.priority == target2.priority);
}

//在尾巴插入一个节点
int list_insert_r(AVLData * list_head,AVLData new_node){
   
   
    if (list_head == NULL) return 0;
//    if (new_node == NULL) return 0; //新建数据节点必须在之前分配好内存
    AVLData * newnode = (AVLData *)malloc(sizeof(AVLData));
    if(newnode == NULL){
   
   
        return -1; //内存开辟失败
    }
    (*newnode)=new_node;
    AVLData * p= list_head;
    //设置新节点数据
    newnode->next = NULL;
    newnode->key=newnode->task.priority;
    while (p->next){
   
   //第一个节点不存数据
        p=p->next;
    }
    p->next = newnode;
    return 0;
}
/**
 * @brief 删除节点,对比任务名,任务优先级和任务函数指针,全部一样删除
 * @param list_head 链表头
 * @param del_node 要删除的节点
 * @return 0-删除成功 -1-删除失败
 * */
int list_node_del(AVLData * list_head,Task_t del_node){
   
   
    AVLData * p = list_head;
    while (p->next){
   
   //
        if(compare_node(p->next->task,del_node)==0){
   
    //如果相等
            break;
        }
        p = p->next;
    }
    if(p->next == NULL )
        return -1; //未找到
    AVLData * q = p->next;
    p->next = p->next->next;
    free(q);
    return 0;
}
/**
 * @brief 遍历节点
 * @param list_head 链表首元结点
 * */
int list_traverse(AVLData * list_head){
   
   
    AVLData * p = list_head;
    p=p->next;
    while (p){
   
   
        printf("节点数据\n");
        p=p->next;
    }
    return 0;
}




///---------------------------AVL树----------------
// 获取节点高度
int get_avltree_height(AVLNode *node) {
   
   
    if (node == NULL) return 0;
    return node->height;
}

// 新建节点
AVLNode* avltree_newNode(AVLData data) {
   
   
    AVLNode* node = (AVLNode*) malloc(sizeof(AVLNode));
    if(node == NULL){
   
   
        _exit(-1);//申请内存失败
    }
    node->data = data;
    node->left = NULL;
    node->right = NULL;
    node->height = 1; // 新节点初始高度设为1
    return node;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值