网站开发技术可行性分析,网站和软件有什么区别,php网站建设含义,新泰网站设计文章目录 一.题目描述二. 思路解析三. 代码实现 一.题目描述
设计你的循环队列实现。 循环队列是一种线性数据结构#xff0c;其操作表现基于 FIFO#xff08;先进先出#xff09;原则并且队尾被连接在队首之后以形成一个循环。它也被称为“环形缓冲器”。 循环队列的一个好… 文章目录 一.题目描述二. 思路解析三. 代码实现 一.题目描述
设计你的循环队列实现。 循环队列是一种线性数据结构其操作表现基于 FIFO先进先出原则并且队尾被连接在队首之后以形成一个循环。它也被称为“环形缓冲器”。 循环队列的一个好处是我们可以利用这个队列之前用过的空间。在一个普通队列里一旦一个队列满了我们就不能插入下一个元素即使在队列前面仍有空间。但是使用循环队列我们能使用这些空间去存储新的值。
你的实现应该支持如下操作
MyCircularQueue(k): 构造器设置队列长度为 k 。 Front: 从队首获取元素。如果队列为空返回 -1 。 Rear: 获取队尾元素。如果队列为空返回 -1 。 enQueue(value): 向循环队列插入一个元素。如果成功插入则返回真。 deQueue(): 从循环队列中删除一个元素。如果成功删除则返回真。 isEmpty(): 检查循环队列是否为空。 isFull(): 检查循环队列是否已满。
二. 思路解析
循环队列给定了长度即空间大小固定为k个但开辟空间为k1个原因如下 当空的时候front和rear相等满的时候也相等所以无法判别增加一个空间不用就可以解决问题。 例如k5只能有五个元素当rear1%k1front时即满。 返回队头元素直接返回front位置即可返回队尾元素因为是rear指向的前一个就有特殊的当rear指向第一个队尾元素而是最后一个此时队尾位置满足reark%k1)。 3.插入元素直接再rear位置上插然后rear但极端情况当rear指向最后一个位置后面此时应该跳到第一个位置即rear rear%k1删除元素直接front,但是当front在最后一个位置此时到第一个位置即frontfront%k1
三. 代码实现 typedef struct {int* a;int front;int rear;int k;
} MyCircularQueue;MyCircularQueue* myCircularQueueCreate(int k) {MyCircularQueue* obj (MyCircularQueue*)malloc(sizeof(MyCircularQueue));obj-a (int*)malloc(sizeof(int)*(k1));obj-front obj-rear 0;obj-k k;return obj;
}bool myCircularQueueIsEmpty(MyCircularQueue* obj) {if(obj-rearobj-front)return true;return false;
}bool myCircularQueueIsFull(MyCircularQueue* obj) {if((obj-rear1)%(obj-k1)obj-front)return true;return false;
}
bool myCircularQueueEnQueue(MyCircularQueue* obj, int value) {if(myCircularQueueIsFull(obj))return false;obj-a[obj-rear] value;obj-rear;obj-rear%(obj-k1);return true;
}bool myCircularQueueDeQueue(MyCircularQueue* obj) {if(myCircularQueueIsEmpty(obj))return false;obj-front;obj-front%(obj-k1);return true;
}int myCircularQueueFront(MyCircularQueue* obj) {if(myCircularQueueIsEmpty(obj))return -1;return obj-a[obj-front];
}int myCircularQueueRear(MyCircularQueue* obj) {if(myCircularQueueIsEmpty(obj))return -1;(obj-rearobj-k)%(obj-k1);return obj-a[(obj-rearobj-k)%(obj-k1)];
}void myCircularQueueFree(MyCircularQueue* obj) {free(obj-a);free(obj);
}