纸上谈兵: 栈 (stack)

  • 时间:
  • 浏览:1
  • 来源:大发pk10_pk10遗漏_大发pk10遗漏

作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明。谢谢!

栈(stack)是简单的数据社会形态,但在计算机中使用广泛。它是有序的元素集合。栈最显著的社会形态是LIFO (Last In, First Out, 后进先出)。当大伙往箱子里存放一叠书时,先存放的书在箱子下面,大伙需用将后存放的书取出来,不能想看 和学会英语早先存放的书。

栈中的每个元素称为另一个多多多多 frame。而最上层元素称为top frame。栈只支持另一个多多多多 操作, pop, top, push。

pop取出栈中最上层元素(8),栈的最上层元素变为早先进入的元素(9)。

top查看栈的最上层元素(8)。

push将另一个多多多多 新的元素(5)装进栈的最上层。

栈不支持但会 操作。愿因着想取出元素12, 需用进行3次pop操作。

栈以及pop, push, top操作

栈最经典的计算机应用是函数调用。每个程序运行总要另一个多多多多多 栈,每个frame中记录了调用函数的参数,自动变量和返回地址。当该函数调用另一个多多多多 新的函数时,栈中会 push另一个多多多多 frame。当函数执行完毕返回时,该frame会pop,从而进入调用该函数的原函数,继续执行。完整性请参阅Linux从程序运行到程序运行

实际使用的栈暂且一定符合数据社会形态的栈。比如说,有的语言允许被调用函数查看非top frame的记录。原先的栈更例如于于下面的经典游戏

 

栈的C实现 (基于表)

愿因着栈是限定了操作的有序的元素集合,什么都有有大伙既可不需用在数组的基础上来实现栈,也可不需用在表的基础上来实现栈。愿因着使用数组来实现栈,大伙需用预留宽裕的空间供栈使用,并需用另一个多多多多 下标来记录最上层元素的位置。

大伙这里使用单向链表来实现栈。大伙可不需用利用介绍表(list)的文章中愿因着定义的操作来实现另一个多多多多 操作,但这里相对独立的重写了代码。

/* By Vamei */
/* use single-linked list to implement stack */
#include <stdio.h>
#include <stdlib.h>

typedef struct node *position;
typedef int ElementTP;

// point to the  head node of the list
typedef struct node *STACK;
 
struct node {
    ElementTP element;
    position next;
};

STACK init_stack(void);
void delete_stack(STACK);
ElementTP top(STACK);
void push(STACK, ElementTP);
ElementTP pop(STACK);
int is_null(STACK);

void main(void)
{
    ElementTP a;
    int i;
    STACK sk;
    sk = init_stack();
    push(sk, 1);
    push(sk, 2);
    push(sk, 8);
    printf("Stack is null? %d\n", is_null(sk));
    for (i=0; i<3; i++) {
        a = pop(sk);
        printf("pop: %d\n", a);
    }

    printf("Stack is null? %d\n", is_null(sk));    
    delete_stack(sk);
}

/*
 * initiate the stack
 * malloc the head node.
 * Head node doesn't store valid data
 * head->next is the top node
 */
STACK init_stack(void)
{
    position np;
    STACK    sk;
    np = (position) malloc(sizeof(struct node));
    np->next     = NULL;  // sk->next is the top node
    sk = np; 
    return sk;
}

/* pop out all elements 
 * and then delete head node
 */
void delete_stack(STACK sk)
{
    while(!is_null(sk)) {
        pop(sk);
    }
    free(sk);
}
/* 
 * View the top frame
 */
ElementTP top(STACK sk)
{
    return (sk->next->element);
}

/*
 * push a value into the stack
 */
void push(STACK sk, ElementTP value) 
{
    position np, oldTop;
    oldTop = sk->next;    

    np = (position) malloc(sizeof(struct node));
    np->element  = value;
    np->next     = sk->next;

    sk->next     = np; 
}

/* 
 * pop out the top value
 */
ElementTP pop(STACK sk)
{
    ElementTP element;
    position top, newTop;
    if (is_null(sk)) {
        printf("pop() on an empty stack");
        exit(1);
    } 
    else {
        top      = sk->next;
        element  = top->element;     
        newTop   = top->next;
        sk->next     = newTop;
        free(top);
        return element;
    } 
}

/* check whether a stack is empty*/
int is_null(STACK sk)
{
    return (sk->next == NULL);
}

输出结果:

Stack is null? 0

pop: 8pop: 2pop: 1Stack is null? 1

总结

栈, LIFO

pop, push, top

欢迎继续阅读“纸上谈兵: 算法与数据社会形态”系列。

Update:

我日后是用双向循环链表实现的栈,并且发现原先没人必要。它不能给栈带来额外的好处,总要增加所需的内存空间。

猜你喜欢

王者荣耀三国版本有哪些更新?三国版本新内容前瞻

王者荣耀三国版本是下有一一有一个 新的版本,主要内容是三国五虎将新皮肤,以及王者模拟战等玩法,以下大伙儿来看下三国版本的具体内容介绍。在新版本中又会有所以新内容上线,目前不

2020-01-21

独立恐怖游戏《虚无大厅》宣传视频公布

更新时间:2017-06-2114:53:11来源:斗蟹游戏编辑:斗蟹 喜欢恐怖游戏的玩家有福了,日前,一款独立恐怖游戏《虚无大厅(HollowHalls)》表态。 宣传视频:

2020-01-21

秋裤畅销!95后“新人类”成苏宁1108“超级拼购日”大买家

IT之家11月9日消息 在昨天进行的苏宁易购1108“超级拼购日”上,苏宁易购单日完成拼购订单超过50万单,其中两成订单来自颜值爆表年轻人,秋裤成为本次拼购活动畅销品。据了解,

2020-01-21

由“RangeError: Invalid status code: 0”错误所引发的思考

最近发现一个基于Node.js平台上的Express框架运行的Web网站老会 报后来一个错误:RangeError:Invalidstatuscode:0网站的源码中有 专门

2020-01-21

国外新型养老:美国“抱团式”养老和德国“同居式”养老

核心提示:美国人的“抱团式”养老和德国人备受追捧的“同居式”养老模式。养老,是有俩个 人人都得面对的难题。想到后来身边的若干好友把房子买在同时,一道晒太阳、散步、聊八卦、寄养

2020-01-21