#include <stdio.h>#include <stdlib.h>#include "base.h"#include "list.h"#include "queue.h"static void LinkedQueue_add(IQueue* queue, int elem);static int LinkedQueue_remove(IQueue* queue);static int LinkedQueue_empty(IQueue* queue);LinkedQueue* newLinkedQueue(IList* list){LinkedQueue* linkedQueue = (LinkedQueue*)malloc(sizeof(LinkedQueue));if (linkedQueue == NULL) {return NULL;}linkedQueue->list = list;linkedQueue->iqueue.add = LinkedQueue_add;linkedQueue->iqueue.remove = LinkedQueue_remove;linkedQueue->iqueue.empty = LinkedQueue_empty;return linkedQueue;}LinkedQueue* newDefLinkedQueue(){LinkedList* linkedList = newLinkedList();if (linkedList == NULL) {return NULL;}return newLinkedQueue(&linkedList->ilist);}void deleteLinkedQueue(LinkedQueue* queue){free(queue);}void deleteDefLinkedQueue(LinkedQueue* queue){LinkedList* linkedList = container_of(queue->list, LinkedList, ilist);deleteLinkedList(linkedList);deleteLinkedQueue(queue);}void LinkedQueue_add(IQueue* queue, int elem){LinkedQueue* linkedQueue = container_of(queue, LinkedQueue, iqueue);linkedQueue->list->push(linkedQueue->list, elem);}int LinkedQueue_remove(IQueue* queue){LinkedQueue* linkedQueue = container_of(queue, LinkedQueue, iqueue);return linkedQueue->list->pop(linkedQueue->list);}int LinkedQueue_empty(IQueue* queue){LinkedQueue* linkedQueue = container_of(queue, LinkedQueue, iqueue);return linkedQueue->list->empty(linkedQueue->list);}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。