栈和队列OJ题

1.设计循环队列

首先,你要去了解出题人的意思,然后才能够去设计相应的思路

如果设计这样的一个以数组为底层的顺序表来实现,那判断满和判断空则冲突了,导致不好判断。

所以Create时可以多为数组多开辟一个空间或者再维护一个size变量用来区分这两种情况以方便判断。

这里我就用多开辟一个空间来解决。

这时就可以分清楚两种情况:

1.当back == front时,则队列为空

2.当back+1 == front是,则队列为满

又因为是循环队列,所以要多多判断溢出情况使用 求余符号(%)

如用 back %= (k+1)和 front %= (k+1)(k为队列存储数据的实际个数)

以将back和front拉回合法访问范围内

进队列和出队列的返回值就可以利用判空和判满来返回

如:

只要理解了前面循环结构该如何构建,空和满该如何判断,就能够很简单的完成后面的接口

注意:时刻谨记**取余符号(%)**使得访问时不会造成非法访问

取队头元素,就可以直接先判是否为空,在访问数组中下标为front的数据则为队头数据

取队尾数据,则要防止当back为0时的时候,因为这个时候访问back-1(-1)就是非法访问了。

给出了一下两种解决方法:

题目不难,就是坑点太多了,容易考虑不周和造成越界访问。

完整代码如下(仅供参考):

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


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

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

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

bool myCircularQueueEnQueue(MyCircularQueue* obj, int value) {
    if(myCircularQueueIsFull(obj))
        return false;
    obj->back %= (obj->k+1);
    obj->a[obj->back] = value;
    obj->back++;
    obj->back %= (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;
    return obj->a[obj->front];
}

int myCircularQueueRear(MyCircularQueue* obj) {
    if(myCircularQueueIsEmpty(obj))
        return -1;
    if(obj->back == 0)
        return obj->a[obj->k];
    return obj->a[obj->back-1];
}


void myCircularQueueFree(MyCircularQueue* obj) {
    obj->front = obj->back = 0;
    free(obj->a);
    free(obj);
}
相关推荐
Andrew_Xzw18 分钟前
数据结构与算法(快速基础C++版)
开发语言·数据结构·c++·python·深度学习·算法
momo卡20 分钟前
MinGW-w64的安装详细步骤(c_c++的编译器gcc、g++的windows版,win10、win11真实可用)
c语言·c++·windows
超的小宝贝1 小时前
数据结构算法(C语言)
c语言·数据结构·算法
凤年徐3 小时前
【数据结构初阶】单链表
c语言·开发语言·数据结构·c++·经验分享·笔记·链表
木子.李3477 小时前
排序算法总结(C++)
c++·算法·排序算法
闪电麦坤958 小时前
数据结构:递归的种类(Types of Recursion)
数据结构·算法
小熊猫写算法er9 小时前
终极数据结构详解:从理论到实践
数据结构
Gyoku Mint9 小时前
机器学习×第二卷:概念下篇——她不再只是模仿,而是开始决定怎么靠近你
人工智能·python·算法·机器学习·pandas·ai编程·matplotlib
纪元A梦9 小时前
分布式拜占庭容错算法——PBFT算法深度解析
java·分布式·算法
px不是xp9 小时前
山东大学算法设计与分析复习笔记
笔记·算法·贪心算法·动态规划·图搜索算法