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

思路展示:

代码实现:

复制代码
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);
}
相关推荐
zxctsclrjjjcph1 小时前
【高并发内存池】从零到一的项目之centralcache整体结构设计及核心实现
开发语言·数据结构·c++·链表
codists1 小时前
《算法导论(第4版)》阅读笔记:p14-p16
算法
zilpher_wang1 小时前
K-means
算法·机器学习·kmeans
柃歌1 小时前
【LeetCode Solutions】LeetCode 176 ~ 180 题解
数据结构·数据库·sql·算法·leetcode
袁气满满~_~1 小时前
LeetCode:101、对称二叉树
算法·leetcode·职场和发展
How_doyou_do2 小时前
Dijkstra
算法
赵和范2 小时前
C++:书架
开发语言·c++·算法
tmiger3 小时前
图像匹配导航定位技术 第 10 章
人工智能·算法·计算机视觉
wuxiguala3 小时前
【文件系统—散列结构文件】
linux·算法
keepDXRcuriosity3 小时前
深入探索快速排序算法:原理与 C 语言实现
c语言·算法·排序算法