【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;
}
相关推荐
Тиё Сиротака5 小时前
红包分配算法的严格数学理论与完整实现
算法
hefaxiang6 小时前
C语言常见概念(下)
c语言·开发语言
potato_may6 小时前
链式二叉树 —— 用指针构建的树形世界
c语言·数据结构·算法·链表·二叉树
Mz12216 小时前
day07 和为 K 的子数组
数据结构
盐焗西兰花6 小时前
鸿蒙学习实战之路 - 图片预览功能实现
学习·华为·harmonyos
java修仙传7 小时前
每日一题,力扣560. 和为 K 的子数组
算法·leetcode
Xudde.7 小时前
friendly2靶机渗透
笔记·学习·安全·web安全·php
知识分享小能手7 小时前
CentOS Stream 9入门学习教程,从入门到精通, CentOS Stream 9 命令行基础 —语法知识点与实战详解(4)
linux·学习·centos
ada7_7 小时前
LeetCode(python)——148.排序链表
python·算法·leetcode·链表
码界奇点7 小时前
Java Web学习 第15篇jQuery从入门到精通的万字深度解析
java·前端·学习·jquery