用C语言实现一个任意类型的队列
创始人
2024-05-29 21:45:13
0

下面是一个简单的无类型队列的实现:

#include 
#include typedef struct Node {void *data;struct Node *next;
} Node;typedef struct Queue {Node *front;Node *rear;int size;
} Queue;void enqueue(Queue *queue, void *data);
void *dequeue(Queue *queue);
void print_queue(Queue *queue);int main() {Queue queue = {NULL, NULL, 0};int a = 10, b = 20, c = 30;char d = 'a', e = 'b', f = 'c';enqueue(&queue, &a);enqueue(&queue, &b);enqueue(&queue, &c);enqueue(&queue, &d);enqueue(&queue, &e);enqueue(&queue, &f);print_queue(&queue);int *x = dequeue(&queue);printf("Dequeued element: %d\n", *x);char *y = dequeue(&queue);printf("Dequeued element: %c\n", *y);print_queue(&queue);return 0;
}void enqueue(Queue *queue, void *data) {Node *new_node = (Node *) malloc(sizeof(Node));new_node->data = data;new_node->next = NULL;if (queue->front == NULL) {queue->front = new_node;queue->rear = new_node;} else {queue->rear->next = new_node;queue->rear = new_node;}queue->size++;
}void *dequeue(Queue *queue) {if (queue->front == NULL) {return NULL;}Node *temp = queue->front;void *data = temp->data;queue->front = queue->front->next;free(temp);queue->size--;if (queue->front == NULL) {queue->rear = NULL;}return data;
}void print_queue(Queue *queue) {if (queue->front == NULL) {printf("Queue is empty.\n");return;}printf("Queue: ");Node *temp = queue->front;while (temp != NULL) {int *x = (int *) temp->data;printf("%d ", *x);temp = temp->next;}printf("\n");
}

上述代码中,使用了结构体Node来表示队列中的每个节点,节点中包含了一个void *类型的数据指针和一个指向下一个节点的指针。

另外,还定义了一个结构体Queue来表示队列本身,包含了队列的头指针、尾指针和大小。其中,void *类型的数据指针可以指向任何类型的数据,因此我们可以使用这个队列来存储不同类型的数据。

对于队列的操作,我们定义了三个函数:enqueue()用于将一个元素加入队列,dequeue()用于从队列中取出一个元素,print_queue()用于打印队列中的所有元素。其中,enqueue()函数需要创建一个新的节点,并将其插入到队列的尾部;dequeue()函数需要从队列的头部取出一个节点,并返回其中的数据指针;print_queue()函数则需要遍历整个队列,并打印每个节点中的数据。

在主函数中,演示了如何使用这个无类型队列来存储不同类型的数据,并进行入队、出队和打印操作。

需要注意的是,在取出队列中的数据时,我们需要将其转换为正确的类型,否则会出现类型不匹配的错误。

【最后一个bug】多平台都有更新和发布,大家可以一键三连,关注+星标,不错过精彩内容~~
在这里插入图片描述

相关内容

热门资讯

翡翠原石 翡翠原石翡翠原石有那些场口翡翠原石场口有很多,并且每个场口下边又有很多小场(缅甸当地称为磨),比较出...
纯苯期货和期权上市 多家产业链... 纯苯期货和期权上市多家产业链企业参与首日交易◎记者 费天元 7月8日,纯苯期货和期权在大连商品交易所...
宇宙中是否有第二个地球? 宇宙中是否有第二个地球?肯定有知稿别的智慧生物,但不一薯巧定像地球宇宙太大了,智慧生物数猛键相距太远...
嘉元科技:储备技术已基本满足固... 嘉元科技:储备技术已基本满足固态电池技术路线需求◎记者 刘逸鹏 7月8日下午,嘉元科技在深圳举行投资...
深圳市盐田港股份有限公司202... 证券代码:000088 证券简称:盐田港 公告编号:2025-30深圳市盐田港股份有限公司2025年...
《牛和鹅》中的作者为什么后来不... 《牛和鹅》中的作者为什么后来不欺负牛了?急!!!!因为作者知道了应该平等地对待它们,不能无缘无故欺负...
女儿远嫁三年后得了重病,我连夜... 女儿远嫁三年后得了重病,我连夜凑了五万,女婿却拒收了,你怎么看?我觉得女婿太任性了。妻子得了重病,治...
什么是消费者市场?消费者市场的... 什么是消费者市场?消费者市场的需求有什么特点?消费者市场,是由那些为满足生活消费需要而购买商品的所有...
云之遥怎么进入地城系统 云之遥怎么进入地城系统云之遥怎么进入地城系统输完帐号密码后选择服务器,连接成功后画面左下角有五个选项...
城市的服务范围是层层嵌套的是什... 城市的服务范围是层层嵌套的是什么意思?具体是指它们的关系是相互关联的,形容各行各业的密切关系.城市提...