美文网首页
0232-用栈实现队列

0232-用栈实现队列

作者: liyoucheng2014 | 来源:发表于2019-01-17 21:14 被阅读0次

用栈实现队列

方案一


要我们在插入元素的时候每次都都从前面插入即可,比如如果一个队列是1,2,3,4,那么我们在栈中保存为4,3,2,1,那么返回栈顶元素1,也就是队列的首元素,则问题迎刃而解。所以此题的难度是push函数,我们需要一个辅助栈tmp,把s的元素也逆着顺序存入tmp中,此时加入新元素x,再把tmp中的元素存回来,这样就是我们要的顺序了,其他三个操作也就直接调用栈的操作即可。

上面那个解法虽然简单,但是效率不高,因为每次在push的时候,都要翻转两边栈,下面这个方法使用了两个栈input和output,其中新进栈的都先缓存在input中,入股要pop和peek的时候,才将input中所有元素移到output中操作,提高了效率。

C-源代码


typedef char LinkStackData;

//节点
typedef struct link_stack_node {
    LinkStackData data;
    struct link_stack_node *next;
}LinkStackNode;

typedef struct link_stack {
    LinkStackNode *top;//栈顶
    int count;//栈大小
}LinkStack;

LinkStack *linkStackCreate() {
    LinkStack *stack = NULL;
    
    stack = (LinkStack *)malloc(sizeof(LinkStack));
    if (stack == NULL) {
        return NULL;
    }
    
    stack->top = NULL;
    stack->count = 0;
    
    return stack;
}

bool linkStackIsEmpty(LinkStack *stack) {
    return stack->count == 0;
}


int linkStackPush(LinkStack *stack, LinkStackData data) {
    LinkStackNode *p = NULL;
    
    p = (LinkStackNode *)malloc(sizeof(LinkStackNode));
    if (p == NULL) {
        return -1;
    }
    
    p->data = data;
    p->next = stack->top;
    stack->top = p;
    stack->count++;
    
    return 0;
}

int linkStackTop(LinkStack *stack, LinkStackData *data) {
    if (linkStackIsEmpty(stack)) {
        return -1;
    }
    
    LinkStackNode *p = stack->top;
    *data = p->data;
 
    return 0;
}

int linkStackPop(LinkStack *stack, LinkStackData *data) {
    if (linkStackIsEmpty(stack)) {
        return -1;
    }
    
    LinkStackNode *p = stack->top;
    *data = p->data;
    stack->top = p->next;
    stack->count--;
    
    free(p);
    
    return 0;
}

void linkStackDestory(LinkStack *stack) {
    LinkStackNode *p = NULL;
    
    while (stack->top) {
        p = stack->top;
        stack->top = p->next;
        stack->count--;
        free(p);
    }
    
    free(stack);
}
typedef struct {
    
    LinkStack *output;
    LinkStack *input;
} MyQueue;

MyQueue* myQueueCreate(int maxSize) {
    
    MyQueue *queue = (MyQueue *)malloc(sizeof(MyQueue));
    queue->output = linkStackCreate();
    queue->input = linkStackCreate();
    
    return queue;
}

void shiftStack(MyQueue *queue) {
    
    if (!linkStackIsEmpty(queue->output)) {
        
        return;
    }
    
    while (!linkStackIsEmpty(queue->input)) {
        
        char data;
        linkStackTop(queue->input, &data);
        linkStackPush(queue->output, data);
        linkStackPop(queue->input, &data);
    }
}

void myQueuePush(MyQueue* obj, int x) {
    
    linkStackPush(obj->input, x);
}

int myQueuePop(MyQueue* obj) {
    
    shiftStack(obj);
    
    char data;
    linkStackPop(obj->output, &data);
    
    return data;
}

int myQueuePeek(MyQueue* obj) {
    
    shiftStack(obj);
    
    char data;
    linkStackTop(obj->output, &data);
    
    return data;
}

bool myQueueEmpty(MyQueue* obj) {
    
    return linkStackIsEmpty(obj->output) && linkStackIsEmpty(obj->input);
}

void myQueueFree(MyQueue* obj) {
    
    linkStackDestory(obj->output);
    linkStackDestory(obj->input);
    free(obj);
}

void test_0232(void) {
    MyQueue *queue = myQueueCreate(5);
    myQueuePush(queue, 1);
    myQueuePush(queue, 2);
    myQueuePush(queue, 3);
    myQueuePush(queue, 4);
    
    while (!myQueueEmpty(queue)) {
        int data = myQueuePop(queue);
        printf("%d\n",data);
    }
}

参考Grandyang

相关文章

  • 算法面试通关-堆栈&队列《三》

    队列 FIFO 栈 FILO 优先队列用堆实现或者二叉查找树 0020-有效的括号0232-用栈实现队列0225-...

  • 0232-用栈实现队列

    用栈实现队列 方案一 要我们在插入元素的时候每次都都从前面插入即可,比如如果一个队列是1,2,3,4,那么我们在栈...

  • 数据结构——栈和队列

    用数组实现栈和队列 用栈实现队列 用队列实现栈 栈和队列的经典算法题最小间距栈宠物收养所 数组实现栈和队列 用数组...

  • leecode刷题(26)-- 用栈实现队列

    leecode刷题(26)-- 用栈实现队列 用栈实现队列 使用栈实现队列的下列操作: push(x) -- 将一...

  • C语言第七次作业:链表

    707. 设计链表 空指针 空节点 225. 用队列实现栈 链式存储栈 双队列实现栈 232. 用栈实现队列 链式...

  • 队列之-队列实现栈

    一、队列实现栈核心算法概述 之前已经描述过了用栈实现队列的功能,见栈系列之-实现队列,那么同样队列也可以用来实现栈...

  • 38_两个有趣的问题

    关键词:通过栈实现队列、通过队列实现栈 0. 通过栈实现队列 用栈实现队列等价于用后进先出的特性实现先进先出的特性...

  • 栈&队列

    一、栈&队列总结 栈/队列的应用接雨水验证栈序列滑动窗口的最大值 栈/队列的特殊实现用两个栈实现队列用两个队列实现...

  • 面试题9: 用两个栈实现队列

    9-1 用两个栈实现队列 9-2 用两个队列实现栈

  • LeetCode 每日一题 [12] 用队列实现栈

    LeetCode 用队列实现栈 [简单] 使用队列实现栈的下列操作: push(x) -- 元素 x 入栈pop(...

网友评论

      本文标题:0232-用栈实现队列

      本文链接:https://www.haomeiwen.com/subject/glywdqtx.html