本来打算使用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;

最低0.47元/天 解锁文章
797

被折叠的 条评论
为什么被折叠?



