zoukankan      html  css  js  c++  java
  • 队列之数组实现

    #include<iostream>
    using namespace std;
    struct Queue
    {
        int maxCnt;
        int* elements;
        int front,rear;
    };
    Queue* createQueue(int max=7)
    {
         Queue* queue = (Queue*)malloc(sizeof(Queue));
         queue->front=0;
         queue->rear=0;
         queue->maxCnt=max+1;//预留一个空间来预防假溢出的情况
         queue->elements = new int[ queue->maxCnt];
         return  queue;
    }
    
    
    bool isFull(Queue* queue)
    {
        return ((queue->rear+1)%queue->maxCnt)==queue->front;
    }
    bool isEmpty(Queue* queue)
    {
        return queue->rear==queue->front;
    }
     
    bool InQueue(Queue* queue,int value)
    {
        if(isFull(queue))
            return 0;
        queue->elements[queue->rear++]=value;
        queue->rear%=queue->maxCnt;
        return 1;
    }
    bool DeQueue(Queue* queue,int* ans)
    {
        if(isEmpty(queue))
          return 0;
        *ans = queue->elements[queue->front++];
        queue->front%=queue->maxCnt;
        return 1;
    }
    bool front(Queue* queue,int* ans)
    {
        if(isEmpty(queue))
          return 0;
        *ans = queue->elements[queue->front];
        return 1;
    }
    
    void clearQueue(Queue* queue)
    {
        int x;
        while(!isEmpty(queue))
        {
            DeQueue(queue,&x);
            cout<<x<<" ";
        }
        cout<<endl;
    }
    
    void outPut(Queue* queue)
    {
        int st = queue->front;
        int ed = queue->rear;
        while(st!=ed)
        {
            cout<<queue->elements[st]<<" ";
            st++;
            st%=queue->maxCnt;
        }
        cout<<endl;
    }
    
     
    void main()
    {
        int len=4;
        Queue* queue = createQueue();
        int v;
        for(int i=0;i<len;i++)
        {
             v = rand() % 100;
             cout<<v<<" ";
             InQueue(queue,v);
    
        }
        cout<<endl;
        outPut(queue);
        clearQueue(queue);
    
        for(int i=0;i<5;i++)
        {
             v = rand() % 100;
             cout<<v<<" ";
             InQueue(queue,v);
    
        }
        cout<<endl;
        outPut(queue);
    
        DeQueue(queue,&v);
        cout<<v<<endl;
        outPut(queue);
    
        front(queue,&v);
        cout<<v<<endl;
        outPut(queue);
    
        DeQueue(queue,&v);
        cout<<v<<endl;
        outPut(queue);
    
        DeQueue(queue,&v);
        cout<<v<<endl;
        outPut(queue);
    
        for(int i=0;i<5;i++)
        {
             v = rand() % 100;
             cout<<v<<" ";
             InQueue(queue,v);
    
        }
        cout<<endl;
        outPut(queue);
        if(!InQueue(queue,v))
            cout<<"fail"<<endl;
        else outPut(queue);
    
        DeQueue(queue,&v);
        cout<<v<<endl;
        outPut(queue);
    
        DeQueue(queue,&v);
        cout<<v<<endl;
        outPut(queue);
    
        DeQueue(queue,&v);
        cout<<v<<endl;
        outPut(queue);
    
        DeQueue(queue,&v);
        cout<<v<<endl;
        outPut(queue);
    
        for(int i=0;i<3;i++)
        {
             v = rand() % 100;
             cout<<v<<" ";
             InQueue(queue,v);
    
        }
        cout<<endl;
    
        outPut(queue);
    
        cin>>len;
    }
  • 相关阅读:
    关于echarts图表在tab页中width:100%失效的问题
    easyui
    小程序中点击事件传参
    微信小程序实现滚动分页加载更多
    使用jquery如何获取现在时间、并且格式化
    只需两步获取任何微信小程序源码
    怎样修改已经审核通过发布成功的微信小程序
    小程序开发swiper如何实现点击图片自定义跳转
    微信小程序如何提交审核并发布?发布问题:小程序只支持https访问
    小程序填坑之路—读取用户信息、缓存其数据、读取其数据
  • 原文地址:https://www.cnblogs.com/kbyd/p/3991674.html
Copyright © 2011-2022 走看看