【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;
}
相关推荐
jghhh01几秒前
基于C#实现与三菱FX系列PLC串口通信
开发语言·算法·c#·信息与通信
ada7_3 分钟前
LeetCode(python)22.括号生成
开发语言·数据结构·python·算法·leetcode·职场和发展
曹轲恒3 分钟前
JVM之垃圾回收算法(GC)
jvm·算法
喵了meme8 分钟前
C语言实战练习
c语言·开发语言
YuTaoShao16 分钟前
【LeetCode 每日一题】1161. 最大层内元素和——BFS
算法·leetcode·宽度优先
White_Can23 分钟前
《C++11:列表初始化》
c语言·开发语言·c++·vscode·stl
黛色正浓24 分钟前
leetCode-热题100-子串合集(JavaScript)
javascript·算法·leetcode
民乐团扒谱机37 分钟前
【微实验】数模美赛备赛MATLAB实战:一文速通各种“马尔可夫”(Markov Model)
开发语言·人工智能·笔记·matlab·数据挖掘·马尔科夫链·线性系统
Z1Jxxx38 分钟前
字符串翻转
开发语言·c++·算法
闻缺陷则喜何志丹38 分钟前
【前缀和 期望】P7875 「SWTR-7」IOI 2077|普及+
c++·算法·前缀和·洛谷·期望