0225-用队列实现栈

用队列实现栈

方案一


这种方法的原理就是每次把新加入的数插到前头,这样队列保存的顺序和栈的顺序是相反的,它们的取出方式也是反的,那么反反得正,就是我们需要的顺序了。我们需要一个辅助队列tmp,把s的元素也逆着顺序存入tmp中,此时加入新元素x,再把tmp中的元素存回来,这样就是我们要的顺序了,其他三个操作也就直接调用队列的操作即可

C-源代码


typedef int LinkQueueData;

//节点
typedef struct link_queue_node {
    LinkQueueData data;
    struct link_queue_node *next;
}LinkQueueNode;

typedef struct link_queue {
    LinkQueueNode *head;//队头
    LinkQueueNode *tail;//队尾
    int count;//队大小
}LinkQueue;


LinkQueue *linkQueueCreate() {
    LinkQueue *queue = NULL;
    
    queue = (LinkQueue *)malloc(sizeof(LinkQueue));
    if (queue == NULL) {
        return NULL;
    }
    
    queue->head = NULL;
    queue->tail = NULL;
    queue->count = 0;
    
    return queue;
}

bool linkQueueIsEmpty(LinkQueue *queue) {
    return queue->count == 0;
}

int linkQueueEnqueue(LinkQueue *queue, LinkQueueData data) {
    if (queue == NULL) {
        return -1;
    }
    
    LinkQueueNode *p = NULL;
    
    p = (LinkQueueNode *)malloc(sizeof(LinkQueueNode));
    if (p == NULL) {
        return -1;
    }
    
    p->data = data;
    p->next = NULL;
    if (queue->head == NULL) {
        queue->head = p;
    }
    else {
        queue->tail->next = p;
    }
    queue->tail = p;
    queue->count++;
    
    return 0;
}

int linkQueueDequeue(LinkQueue *queue, LinkQueueData *data) {
    if (queue == NULL || linkQueueIsEmpty(queue)) {
        return -1;
    }
    
    *data = queue->head->data;
    
    LinkQueueNode *p = queue->head;
    p = queue->head;
    queue->head = queue->head->next;
    queue->count--;
    
    if (queue->head == NULL) {
        queue->tail = NULL;
    }
    
    free(p);
    
    return 0;
}

void linkQueueDestory(LinkQueue *queue) {
    
    if (queue != NULL && !linkQueueIsEmpty(queue)) {
        
        LinkQueueData data;
        while (!linkQueueIsEmpty(queue)) {
            int ret = linkQueueDequeue(queue, &data);
            if (ret != 0) {
                printf("delete failure\n");
            }
        }
        
        free(queue);
    }
    
}


typedef struct {
    
    LinkQueue *q;
} MyStack;

/** Initialize your data structure here. */
MyStack* myStackCreate(int maxSize) {
    
    MyStack *stack = (MyStack *)malloc(sizeof(MyStack));
    stack->q = linkQueueCreate();
    
    return stack;
}

/** Push element x onto stack. */
void myStackPush(MyStack* obj, int x) {
    
    LinkQueue *queue = linkQueueCreate();
    
    while(!linkQueueIsEmpty(obj->q)) {
        
        linkQueueEnqueue(queue, obj->q->head->data);
        
        int data = 0;
        linkQueueDequeue(obj->q, &data);
    }
    
    linkQueueEnqueue(obj->q, x);
    
    while(!linkQueueIsEmpty(queue)) {
        
        linkQueueEnqueue(obj->q, queue->head->data);
        
        int data = 0;
        linkQueueDequeue(queue, &data);
    }
    
    free(queue);
}

/** Removes the element on top of the stack and returns that element. */
int myStackPop(MyStack* obj) {
    
    int data;
    linkQueueDequeue(obj->q, &data);
    
    return data;
}

/** Get the top element. */
int myStackTop(MyStack* obj) {
    
    return obj->q->head->data;
}

/** Returns whether the stack is empty. */
bool myStackEmpty(MyStack* obj) {
    
    return linkQueueIsEmpty(obj->q);
}

void myStackFree(MyStack* obj) {
    
    linkQueueDestory(obj->q);
    
    free(obj);
}

void test_0225(void) {
    MyStack *stack = myStackCreate(5);
    myStackPush(stack, 1);
    myStackPush(stack, 2);
    myStackPush(stack, 3);
    myStackPush(stack, 4);
    
    while (!myStackEmpty(stack)) {
        int data = myStackPop(stack);
        printf("%d\n", data);
    }
}

参考Grandyang

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容

  • 栈 栈的英文单词是Stack,它代表一种特殊的线性表,这种线性表只能在固定一端(通常认为是线性表的尾端)进行插入,...
    Jack921阅读 1,497评论 0 5
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,093评论 1 32
  • 栈 栈: 限定仅在表尾进行插入和删除操作的线性表; 后进先出(LIFO)。 在表尾进行操作,表尾是栈顶;最新进栈的...
    IAM四十二阅读 882评论 0 2
  • 本文内容取自于小甲鱼的数据结构与算法。http://www.jianshu.com/p/230e6fde9c75 ...
    阿阿阿阿毛阅读 2,877评论 0 7
  • 站在你面前, 是如此的熟悉, 又是如此的陌生; 抬望眼, 霾中识城, 踩刹车,辨红灯,还是绿灯? 顿感,彭州石化贻...
    阿里Alex阅读 327评论 0 1