首页 > 其他 > 详细

用双队列模拟栈及用栈逆置队列

时间:2019-05-04 22:53:04      阅读:210      评论:0      收藏:0      [点我收藏+]

双队列模拟栈的基本操作

#include<stdio.h>
#include<stdlib.h>
#define maxsize 30
typedef int datatype;
typedef struct{
    datatype data[maxsize]; 
    int front,rear;
}SeqQueue;
//置空栈 
void Initial(SeqQueue *q1,SeqQueue *q2){
    q1->front= 0,q1->rear = 0;
    q2->front = 0,q2->rear= 0;
} 

int QueueIsEmpty(SeqQueue *q){
    return q->rear == q->front; 
}

int QueueIsFull(SeqQueue *q){
    return q->front ==(q->rear+1)%maxsize;
}

int EnQueue(SeqQueue *q,datatype x){
    if(QueueIsFull(q))
       return 0;
    q->data[q->rear++] = x;
    return 1;
}

int DeQueue(SeqQueue *q,datatype *x){
    if(QueueIsEmpty(q))
       return 0;
       *x = q->data[q->front];
    q->front = (q->front+1)%maxsize;
    return 1;
}

//判断栈空 
int StackIsEmpty(SeqQueue *q1,SeqQueue *q2){
    return QueueIsEmpty(q1)&&QueueIsEmpty(q2);
}
//判断栈满 
int StackIsFull(SeqQueue *q1,SeqQueue *q2){
    return QueueIsFull(q1)||QueueIsFull(q2);
}

//进栈 
int StackPush(SeqQueue *q1,SeqQueue *q2,datatype x){
    if(StackIsFull(q1,q2))
       return 0;
    if(StackIsEmpty(q1,q2))
       EnQueue(q1,x);
    if(!QueueIsEmpty(q1))
       EnQueue(q1,x);
    if(QueueIsEmpty(q1))
       EnQueue(q2,x);
       return 1;
}

//出栈 
int StackPop(SeqQueue *q1,SeqQueue *q2,datatype *x){
    if(StackIsEmpty(q1,q2))    //判断栈空 
       return 0;
    if(!QueueIsEmpty(q1)){     //若q1不为空 
        while(!QueueIsEmpty(q1)){   
            DeQueue(q1,x);     //出q1 
            EnQueue(q2,*x);    //进q2
        }
     }
    else                       //若q1为空 
         while(!QueueIsEmpty(q2)){
            DeQueue(q2,x);     //出q2 
            EnQueue(q1,*x);    //进q1 
         } 
    return 1;
} 

用栈逆置队列

#include<stdio.h>
#include<stdlib.h>
#define maxsize  30
typedef int datatype;
typedef struct{
    datatype data[maxsize];
    int top;
}SeqStack;

typedef struct{
    datatype data[maxsize];
    int front,rear;
}SeqQueue;
//初始化栈和队列 
void Initial(SeqStack *s,SeqQueue *q){
    s->top = -1;
    q->front = 0,q->rear = 0; 
    printf("初始化成功\n");
}
//判断队满 
int QueueFull(SeqQueue *q){
    return q->front == (q->rear+1)%maxsize;
}
//判断队空 
int QueueEmpty(SeqQueue *q){
    return q->rear == q->front;
 } 
 //出队 
int DeQueue(SeqQueue *q,datatype *x){
    if(QueueEmpty(q)) 
       return 0;
       x = &q->data[q->front];
    q->front  = (q->front+1)%maxsize;
    return 1;
}
//进队 
int EnQueue(SeqQueue *q,datatype x){
    if(QueueFull(q))
        return 0;
    q->data[q->rear++] = x;
    return 1;
}
//判断栈满 
int IsFull(SeqStack *s){
    return s->top == maxsize-1;
}
//判断栈空 
int  IsEmpty(SeqStack *s){
    return s->top == -1;
}
//进栈 
int Push(SeqStack *s,datatype x){
    if(IsFull(s)) 
       return 0;
    s->data[++s->top] = x;
    return 1;
}
//出栈 
int Pop(SeqStack *s,datatype *x){
    if(IsEmpty)
       return 0;
       x = &s->data[s->top];
    return s->data[s->top--];
}

//队列逆置 
void Reverse(SeqStack *s,SeqQueue *q){
     datatype x;
     while(!QueueEmpty(q)){
        x = DeQueue(q,&x);
        Push(s,x);
     }
     while(!IsEmpty(s)){
        x = Pop(s,&x);
        EnQueue(q,x);
     }
}

int main(){
    SeqStack *s = (SeqStack*)malloc(maxsize*sizeof(SeqStack));
    SeqQueue *q = (SeqQueue*)malloc(maxsize*sizeof(SeqQueue));
    Initial(s,q);
    int x = 0,i;
    //给队列赋值 
    printf("请输入进队元素\n");
    scanf("%d",&i);
    while(i!=-1){ 
        EnQueue(q,i);
        scanf("%d",i);
    }
    
    Reverse(s,q);
    while(!QueueEmpty(q)){
        printf("队列中的元素分别为:%d",q->data[q->front--]);
    }
}

用双队列模拟栈及用栈逆置队列

原文:https://www.cnblogs.com/susususu/p/10810049.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!