【Leetcode】【实现循环队列】【数据结构】


代码实现:

c 复制代码
typedef struct {
    int front;
    int back;
    int k;
    int* a;
    
} MyCircularQueue;

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

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

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

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

bool myCircularQueueDeQueue(MyCircularQueue* obj) {
    if(myCircularQueueIsEmpty(obj))
    {
    
        return false;
    }
    else 
        ++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) {
    if(myCircularQueueIsEmpty(obj))
    return -1;
    else
    return obj->a[(obj->back-1+obj->k+1)%(obj->k+1)];
}

void myCircularQueueFree(MyCircularQueue* obj) {
    free(obj->a);
    obj->a=NULL;
    free(obj);
    obj=NULL;
}
相关推荐
赶飞机偏偏下雨1 分钟前
【Java笔记】单例模式
java·笔记·单例模式
初级炼丹师(爱说实话版)2 分钟前
2025算法八股——深度学习——优化器小结
人工智能·深度学习·算法
滴滴滴嘟嘟嘟.7 分钟前
Qt UDP通信学习
qt·学习·udp
10001hours9 分钟前
C语言第12讲
c语言·开发语言
努力的小帅19 分钟前
C++_哈希
开发语言·c++·学习·算法·哈希算法·散列表
GoldenaArcher24 分钟前
OpenAPI Specification 系列笔记 III
笔记
福赖30 分钟前
《MySQL基础——C 语言链接》
c语言·数据库·mysql
Christo339 分钟前
TFS-2023《Fuzzy Clustering With Knowledge Extraction and Granulation》
人工智能·算法·机器学习·支持向量机
过河卒_zh156676640 分钟前
AI内容标识新规实施后,大厂AI用户协议有何变化?(二)百度系
人工智能·算法·aigc·算法备案·生成合成类算法备案
zzZ656541 分钟前
支持向量机(SVM)学习报告
学习·机器学习·支持向量机