622.设计循环队列


c 复制代码
typedef struct {
    int* a;
    int head;
    int tail;
    int k;
} MyCircularQueue;

bool myCircularQueueIsEmpty(MyCircularQueue* obj);
bool myCircularQueueIsFull(MyCircularQueue* obj);



//初始化
MyCircularQueue* myCircularQueueCreate(int k) {
    MyCircularQueue* obj=(MyCircularQueue*)malloc(sizeof(MyCircularQueue));

    obj->a=(int*)malloc(sizeof(int)*(k+1));
    obj->head=0;
    obj->tail=0;
    obj->k=k;

    return obj;
}
//放入数据
bool myCircularQueueEnQueue(MyCircularQueue* obj, int value) {
    if(myCircularQueueIsFull(obj))
        return false;

    obj->a[obj->tail]=value;
    obj->tail++;
    (obj->tail)%=(obj->k+1);
    return true;
}
//删前面的数据置空
bool myCircularQueueDeQueue(MyCircularQueue* obj) {
    if(myCircularQueueIsEmpty(obj))
        return false;

    ++obj->head;

    obj->head%=(obj->k+1);
    return true;
}
//取头
int myCircularQueueFront(MyCircularQueue* obj) {
    if(myCircularQueueIsEmpty(obj))
        return -1;
    else
        return obj->a[obj->head];
}
//取尾
int myCircularQueueRear(MyCircularQueue* obj) {
    if(myCircularQueueIsEmpty(obj))
        return -1;
    else
        return obj->a[(obj->tail+obj->k)%(obj->k+1)];

}
//判空
bool myCircularQueueIsEmpty(MyCircularQueue* obj) {
    return obj->head==obj->tail;
}
//判满
bool myCircularQueueIsFull(MyCircularQueue* obj) {
    return (obj->tail+1)%(obj->k+1)==obj->head;
}
//释放
void myCircularQueueFree(MyCircularQueue* obj) {
    free(obj->a);
    free(obj);
}

/**
 * Your MyCircularQueue struct will be instantiated and called as such:
 * MyCircularQueue* obj = myCircularQueueCreate(k);
 * bool param_1 = myCircularQueueEnQueue(obj, value);
 
 * bool param_2 = myCircularQueueDeQueue(obj);
 
 * int param_3 = myCircularQueueFront(obj);
 
 * int param_4 = myCircularQueueRear(obj);
 
 * bool param_5 = myCircularQueueIsEmpty(obj);
 
 * bool param_6 = myCircularQueueIsFull(obj);
 
 * myCircularQueueFree(obj);
*/

循环队列就是在有限空间保证先进先出,重复使用

我们在这里定义两个指针,一个队头指针head和一个队尾指针tail都指向队头。当放入数据时(push),tail指针++并且指向放入元素的下一个位置。当删去数据时(pop),直接移动head让head++就删去了。但是这里有一个问题,一开始head=tail为空当随着往下进行的时候,head=tail为满。

所以我们这里多开一个空间,开k+1个空间但是只放进k个元素。

创建一个结构体把,头指针和尾指针还有整个数组以及元素个数管理起来。

开k+1个空间,但是只放进k个元素。


判空:当在这种情况下时,head和tail相等时只会是在为空的时候。所以判空时,只需判断head是否等于tail。

判满:结合上图,当元素放满时,tail的下一个位置就是head,根据取模得到关系(tail+1)%(k+1)==head

先判断是否为满,在tail指针处放入值然后让tail++往后走。因为是循环队列要注意tail到最后时要形成循环队列,所以tail指针要返回去。

头指针往后走删除数据,走到最后也要返回去。

取头:如果为空就返回-1,否则返回头指针的节点。

取尾:这里还有另外一种写法,如果tail为0也就是放满了tail又循环回来了,此时取下标为k位置的数。如果是正常情况就取tail-1。

相关推荐
月盈缺8 小时前
学习嵌入式的第二十二天——数据结构——双向链表
数据结构·学习·链表
科大饭桶9 小时前
C++入门自学Day14-- Stack和Queue的自实现(适配器)
c语言·开发语言·数据结构·c++·容器
躲在云朵里`10 小时前
深入理解数据结构:从数组、链表到B树家族
数据结构·b树
1白天的黑夜113 小时前
链表-24.两两交换链表中的结点-力扣(LeetCode)
数据结构·leetcode·链表
养成系小王19 小时前
四大常用排序算法
数据结构·算法·排序算法
闪电麦坤9520 小时前
数据结构:从前序遍历序列重建一棵二叉搜索树 (Generating from Preorder)
数据结构··二叉搜索树
闪电麦坤9520 小时前
数据结构:二叉树的遍历 (Binary Tree Traversals)
数据结构·二叉树·
球king20 小时前
数据结构中邻接矩阵中的无向图和有向图
数据结构
野渡拾光1 天前
【考研408数据结构-05】 串与KMP算法:模式匹配的艺术
数据结构·考研·算法
pusue_the_sun1 天前
数据结构:二叉树oj练习
c语言·数据结构·算法·二叉树