• 队列的基本操作以及C语言实现


    队列的基本操作:
    1.Enqueue:将元素插入队列尾部。
    2.Dequeue:从队列头部移除元素。
    3.Front:获取队列头部元素。
    4.IsEmpty:检查队列是否为空。
    5.IsFull:检查队列是否已满。
    代码实现:

    #include 
    
    #define MAX_SIZE 100
    
    // 定义队列结构
    typedef struct {
        int data[MAX_SIZE];
        int front;
        int rear;
    } Queue;
    
    // 初始化队列
    void initQueue(Queue *queue) {
        queue->front = -1;
        queue->rear = -1;
    }
    
    // 入队操作
    void enqueue(Queue *queue, int value) {
        if ((queue->rear + 1) % MAX_SIZE == queue->front) {
            printf("满了.\n");
            return;
        }
        if (queue->front == -1) {
            queue->front = 0;
        }
        queue->rear = (queue->rear + 1) % MAX_SIZE;
        queue->data[queue->rear] = value;
    }
    
    // 出队操作
    int dequeue(Queue *queue) {
        if (queue->front == -1) {
            printf("空了\n");
            return -1; // 返回一个特定的错误值
        }
        int value = queue->data[queue->front];
        if (queue->front == queue->rear) {
            queue->front = -1;
            queue->rear = -1;
        } else {
            queue->front = (queue->front + 1) % MAX_SIZE;
        }
        return value;
    }
    
    // 获取队列头部元素
    int front(Queue *queue) {
        if (queue->front == -1) {
            printf("空了.\n");
            return -1; // 返回一个特定的错误值
        }
        return queue->data[queue->front];
    }
    
    // 检查队列是否为空
    int isEmpty(Queue *queue) {
        return queue->front == -1;
    }
    
    // 检查队列是否已满
    int isFull(Queue *queue) {
        return (queue->rear + 1) % MAX_SIZE == queue->front;
    }
    
    int main() {
        Queue queue;
        initQueue(&queue);
    
        enqueue(&queue, 10);
        enqueue(&queue, 20);
        enqueue(&queue, 30);
    
        printf("Front element: %d\n", front(&queue));
    
        while (!isEmpty(&queue)) {
            printf("Dequeued element: %d\n", dequeue(&queue));
        }
    
        return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
  • 相关阅读:
    vue中的模板语法
    怎样实现网页端im即时通讯中的@人功能
    【Android面试八股文】在onResume中是否可以测量宽高?
    trivy 获取基础镜像源码分析
    【云原生】无VIP稳定性和可扩展性更强的k8s高可用方案讲解与实战操作
    AcWing 4405. 统计子矩阵 双指针+二维前缀和
    C++内存池
    Vue源码解析之mustache模板引擎
    大数据下一代变革之必研究数据湖技术Hudi原理实战双管齐下-上
    Unity UGUI(一)基础组件
  • 原文地址:https://blog.csdn.net/wasane/article/details/133802067