[数据结构]设计循环队列

思路展示:

代码实现:

typedef struct {
    int *a;
    int front;
    int rear;
    int k;
} MyCircularQueue;


bool myCircularQueueIsEmpty(MyCircularQueue* obj);


bool myCircularQueueIsFull(MyCircularQueue* obj);
MyCircularQueue* myCircularQueueCreate(int k) {
    MyCircularQueue* obj=(MyCircularQueue*)malloc(sizeof(MyCircularQueue));
    obj->front=obj->rear=0;
    obj->a=(int *)malloc(sizeof(int)*(k+1));
    obj->k=k;
    return obj;
}


bool myCircularQueueEnQueue(MyCircularQueue* obj, int value) {
    if(myCircularQueueIsFull(obj))
    {
        return false;
    }
    obj->a[obj->rear]=value;
    obj->rear++;
    obj->rear%=(obj->k+1);
    return true;
}


bool myCircularQueueDeQueue(MyCircularQueue* obj) {
    if(myCircularQueueIsEmpty(obj))
    {
        return false;
    }
    ++obj->front;
    obj->front%=(obj->k+1);
    return true;
}


int myCircularQueueFront(MyCircularQueue* obj)//取第一个元素
{
    if(myCircularQueueIsEmpty(obj))
    {
        return -1;
    }else
    {
        return obj->a[obj->front];
    }
}


int myCircularQueueRear(MyCircularQueue* obj) {
    //return obj->a[obj->rear-1];  不能这样访问,如果这样访问那么当rear移动到开头那么rear-1就是-1就是越界访问了
    if( myCircularQueueIsEmpty(obj))
    {
        return -1;
    }else{
        return obj->a[(obj->rear-1+obj->k+1)%(obj->k+1)];//如果rear-1>0那么rear-1+k再模k是不变的
    }
}


bool myCircularQueueIsEmpty(MyCircularQueue* obj) {
    return obj->front==obj->rear;
}


bool myCircularQueueIsFull(MyCircularQueue* obj) {
    return (obj->rear+1)%(obj->k+1)==obj->front;
}


void myCircularQueueFree(MyCircularQueue* obj) {
    free(obj->a);
    free(obj);
}
相关推荐
GIS小天38 分钟前
AI预测体彩排3新模型百十个定位预测+胆码预测+杀和尾+杀和值2025年3月4日第9弹
人工智能·算法·机器学习·彩票
三水气象台1 小时前
对ArrayList中存储的TreeNode的排序回顾
java·数据结构·算法·huffman tree
@心都2 小时前
机器学习数学基础:40.结构方程模型(SEM)中卡方值与卡方自由度比
人工智能·算法·机器学习
@心都2 小时前
机器学习数学基础:39.样本和隐含和残差协方差矩阵
算法·机器学习·矩阵
南棱笑笑生3 小时前
20250304在飞凌OK3588-C的linux R4下提高温度控制阈值为95度
java·linux·算法
FOUR_A3 小时前
【LLM】从零开始实现 LLaMA3
人工智能·算法·机器学习·大模型·llama
__echooo3 小时前
【大模型】Llama 3.2 大语言模型初探:模型权重下载
人工智能·算法·ubuntu·语言模型·自动驾驶·llama
Erik_LinX4 小时前
算法日记33:14届蓝桥C++B冶炼金属(二分答案)
开发语言·c++·算法
AIzealot无4 小时前
力扣hot 100之矩阵四题解法总结
算法·leetcode·矩阵
疯狂的代M夫4 小时前
数据结构【AVL树(平衡二叉树)】
数据结构