栈和队列OJ题——15.循环队列

15.循环队列


622. 设计循环队列 - 力扣(LeetCode)


复制代码
*
解题思路:
通过一个定长数组实现循环队列
入队:首先要判断队列是否已满,再进行入队的操作,入队操作需要考虑索引循环的问题,当索引越界,需要让它变成最小值
出队:首先要判断队列是否为空,再进行出队操作,出队也需要考虑索引循环的问题
判空: 队头 == 队尾
判满: 队尾 + 1 == 队头
*/
复制代码
typedef struct 
{
    int*_arr;
    int _front;
    int _rear;
    int k;
} MyCircularQueue;

bool myCircularQueueIsEmpty(MyCircularQueue* obj)//是否为空
{
    if(obj->_front==obj->_rear)
    {
        return true;
    }
    else
    {
        return false;
    }
}

bool myCircularQueueIsFull(MyCircularQueue* obj) 
{
    if(  (obj->_rear+1)%(obj->k+1)==obj->_front)
    {
        return true;
    }
    else
    {
        return false;
    }
}


MyCircularQueue* myCircularQueueCreate(int k) 
{
    MyCircularQueue*Queue=(MyCircularQueue*)malloc(sizeof(MyCircularQueue));
    if(Queue==NULL)
    {
        perror("malloc");
        exit(-1);
    }

    int*arr=(int*)malloc(sizeof(int)*(k+1));
    if(arr==NULL)
    {
        perror("malloc");
        exit(-1);
    }
    Queue->_arr=arr;

    Queue->_front=Queue->_rear=0;
    Queue->k=k;

    return Queue;
}

bool myCircularQueueEnQueue(MyCircularQueue* obj, int value) //入队
{
    if(myCircularQueueIsFull(obj)==false )
    {
        obj->_arr[obj->_rear]=value;
        obj->_rear++;
        obj->_rear= obj->_rear%(obj->k+1);

        return true;
    }
    else
    {
        return false;

    }
}

bool myCircularQueueDeQueue(MyCircularQueue* obj) //出队
{
    if(myCircularQueueIsEmpty(obj)==false )
    {
        obj->_front++;
       obj->_front= obj->_front%(obj->k+1);

        return true;
    }
    else
    {
        return false;

    }
}

int myCircularQueueFront(MyCircularQueue* obj) 
{
    if(myCircularQueueIsEmpty( obj)==true)
    {
        return -1;
    }
    else
    {
    return obj->_arr[obj->_front];
    }
}

int myCircularQueueRear(MyCircularQueue* obj) 
{
     if(myCircularQueueIsEmpty( obj)==true)
    {
        return -1;
    }
    else
    {
     return obj->_arr[(obj->_rear+obj->k)%(obj->k+1)];
    }

}



void myCircularQueueFree(MyCircularQueue* obj) 
{
    free(obj->_arr);
    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);
*/
相关推荐
CoovallyAIHub1 小时前
VisionClaw:智能眼镜 + Gemini + Agent,看一眼就能帮你搜、帮你发、帮你做
算法·架构·github
Titan20241 小时前
map和set的封装学习笔记
数据结构·c++
CoovallyAIHub1 小时前
低空安全刚需!西工大UAV-DETR反无人机小目标检测,参数减少40%,mAP50:95提升6.6个百分点
算法·架构·github
CoovallyAIHub1 小时前
IEEE Sensors | 湖南大学提出KGP-YOLO:先定位风电叶片再检测缺陷,三数据集mAP均超87%
算法
Yupureki2 小时前
《算法竞赛从入门到国奖》算法基础:动态规划-路径dp
数据结构·c++·算法·动态规划
副露のmagic2 小时前
数组章节 leetcode 思路&实现
算法·leetcode·职场和发展
荣光属于凯撒2 小时前
P2176 [USACO11DEC] RoadBlock S / [USACO14FEB] Roadblock G/S
算法·图论
雨季mo浅忆3 小时前
记录利用Cursor快速实现拖拽式问卷题型创建
算法
Yzzz-F3 小时前
2018-2019 ACM-ICPC, Asia Dhaka Regional ContestC[数论]
算法
Frostnova丶3 小时前
LeetCode 3474. 字典序最小的生成字符串
算法·leetcode·职场和发展