【1】栈的概念

栈是限制在一端进行插入操作和删除操作的线性表(俗称堆栈),
允许进行操作的一端称为“栈顶”,另一固定端称为“栈底”,当栈中
没有元素时称为“空栈”。

【2】特点 ##

后进先出(LIFO)。

【3】顺序栈(sqstack)

定义数据类型
定义结构体  top = 0, top = -1
创建一个空的栈
判断栈是否为空
判断栈是否为满
入栈(压栈)
出栈(弹栈)
打印栈的数据

【4】链式栈(linkstack)

定义数据类型
定义结构体
创建一个空的栈
判断栈是否为空
入栈(压栈)
出栈(弹栈)
打印栈的数据

【5】代码

/*顺序栈*/
#include <stdio.h>
#include <stdlib.h>
#define MAX 100
#define START 1 
typedef int datatype_t;

struct sqstack
{
    datatype_t data[MAX];
    int top;
};

struct sqstack * sqstack_create()
{
    struct sqstack *tmp=(struct sqstack *)malloc(sizeof(struct sqstack));
#if START
    tmp->top=-1;
#else
    tmp->top=0;
#endif
    return tmp;
}

int sqstack_isempty(struct sqstack *ss)
{
#if START
    return (ss->top==-1)?1:0;
#else
    return (ss->top==0)?1:0;
#endif
}

int sqstack_isfull(struct sqstack *ss)
{
#if START
    return (ss->top==MAX-1)?1:0;
#else
    return (ss->top==MAX)?1:0;
#endif
}

void sqstack_push(struct sqstack *ss,datatype_t value)
{
    if(sqstack_isfull(ss))
    {
        printf("full\n");
        return;
    }
#if START
    ss->data[++(ss->top)]=value;
#else
    ss->data[(ss->top)++]=value;
#endif
}

datatype_t sqstack_pop(struct sqstack *ss)
{
    if(sqstack_isempty(ss))
    {
        printf("empty\n");
        return -1;
    }
#if START
    return ss->data[(ss->top)--];
#else
    return ss->data[--(ss->top)];
#endif
}

void sqstack_print(struct sqstack *ss)
{
    int i;
    for(i=0;i<=ss->top;i++)
    {
        printf("%d ",ss->data[i]);
    }
    putchar(10);
}


int main()
{
    struct sqstack *ss=sqstack_create();

    int i;
    for(i=0;i<5;i++)
    {
        sqstack_push(ss,i);
    }
    //sqstack_print(ss);
    while(sqstack_isempty(ss)==0)
        printf("%d ",sqstack_pop(ss));
    putchar(10);
    free(ss);
    return 0;
}
/* 链式栈 */
#include <stdio.h>
#include <stdlib.h>
typedef int datatype_t;

struct node
{
    datatype_t data;
    struct node *next;
};

struct node *linkstack_create()
{
    struct node *tmp=(struct node *)malloc(sizeof(struct node));
    tmp->next=NULL;
    return tmp;
}

int linkstack_isempty(struct node *ls)
{
    return (ls->next==NULL)?1:0;
}

void linkstack_push(struct node *ls,datatype_t value)
{
    struct node *tmp=(struct node *)malloc(sizeof(struct node));
    tmp->data=value;
    tmp->next=ls->next;
    ls->next=tmp;
}

datatype_t linkstack_pop(struct node *ls)
{
    if(linkstack_isempty(ls)==1)
    {
        printf("empty");
        return -1;
    }
    struct node *p=ls->next;
    ls->next=p->next;
    datatype_t tmp=p->data;
    free(p);
    return tmp;

}


int main()
{
    int i;
    struct node *linkstack;
    linkstack=linkstack_create();

    for(i=0;i<5;i++)
        linkstack_push(linkstack,i);

    while(linkstack_isempty(linkstack)==0)
    {
        printf("%d ",linkstack_pop(linkstack));
    }
    putchar(10);
    return 0;
}

【数据结构】栈的更多相关文章

  1. 使用Html5多媒体实现微信语音功能

    这篇文章主要介绍了使用Html5多媒体实现微信语音功能,需要的朋友可以参考下

  2. canvas 实现 github404动态效果的示例代码

    本篇文章主要介绍了canvas 实现 github404动态效果的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  3. xcode7 – 谁在创建文件“/private/var/tmp/Untitled-*.uicatalog”?

    我正在调查为什么TeamCity构建代理程序用完了磁盘,并且在/private/var/tmp中找到了超过11,000个文件,它们都以Untitled-.uicatalog行命名.每个文件至少0.6MB.总磁盘占用空间约为4GB.这些文件可以追溯到几个月,所以他们能够重新启动.谁在创造他们?Xcode在编译至少有一个图像的xcassets目录时创建这些目录.我可以删除它们吗?

  4. ios – MonoTouch:tmp文件夹位置?

    在MonoTouch中使用.NET框架,如何访问/tmp文件夹?解决方法这将返回您的应用程序的tmp文件夹

  5. swift篇第一期:简单的数据结构

    首先我们可以去使用Playground来编码,并且会实时的显示对应的编码信息,这样我们就不用每次都去运行程序来显示输出的东西了哦,也方便了我们对某些语句的验证,这个是比较赞的var与let前者为可变修饰符,后者为不可变从字面意思我们就可以很好的区分了常用的类型呢,跟其他语言基本相同啦,主要有几种:1.int类型2.Float,Double类型3.String类型4.Boolean类型当我们去声明一

  6. Swift 集合数据结构性能分析

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  7. Swift中的集合类数据结构

    在那种情况下,你将会需要一种基本的集合类数据结构。继续学习,你将会比较成熟的Cocoa数据结构与对应的纯Swift结构的性能。常见iOS数据结构iOS中三种最常用的数据结构是arrays,dictionaries和sets。除了在Swift和Objective-C中旧的Foundation框架中的数据结构,现在又有了新的仅支持Swift版本的数据结构与语言紧密结合在一起。Swift数组是同质的,意味着每一个Swift数组都只包含一种类型的对象。

  8. 11.Swift 中的类和结构体

    举例来说,以下情境中适合使用结构体:1.几何形状的大小,封装一个width属性和height属性,两者均为Double类型。这次就讲到这里,下次我们继续

  9. Swift解读专题三——基础运算符

    Swift解读专题三——基础运算符一、引言运算符是编程语言不可缺少的一个部分,Swift中除了支持C中的运算符外,还提供了一些更加强大的运算符功能,例如取余符%可以用来计算浮点数,另外新增了两种范围运算符。Swift中有3类运算符:1.一元运算符运算符作用于一个操作数,可以出现在操作数前或者操作数后。

  10. a place you can learn algorithms and data structures(算法和数据结构) in swift

    https://github.com/raywenderlich/swift-algorithm-club

随机推荐

  1. 【数据结构】单调栈

    显然,每个发射站发来的能量有可能被0或1或2个其他发射站所接受,特别是为了安全,每个发射站接收到的能量总和是我们很关心的问题。由于数据很多,现只需要你帮忙计算出接收最多能量的发射站接收的能量是多少。输入输出格式输入格式:第1行:一个整数N;第2到N+1行:第i+1行有两个整数Hi和Vi,表示第i个人发射站的高度和发射的能量值。输入输出样例输入样例:34235610输出样例:7题解中有讲解代码实现

  2. BZOJ 1798 [Ahoi2009] Seq 维护序列seq [线段树+多重标记下传]【数据结构】

    有长为N的数列,不妨设为a1,a2,…Input第一行两个整数N和P。第二行含有N个非负整数,从左到右依次为a1,aN,。表示把所有满足t≤i≤g的ai改为ai×c。操作2:“2tgc”。同一行相邻两数之间用一个空格隔开,每行开头和末尾没有多余空格。Output对每个操作3,按照它在输入中出现的顺序,依次输出一行一个整数表示询问结果。SampleInput7431234567512553242379313347SampleOutput2358HINT初始时数列为。对第5次操作,和为29+34+15+16=

  3. 陈越《数据结构》第一讲 基本概念

    陈越《数据结构》第一讲基本概念1什么是数据结构1.1引子例子:如何在书架上摆放图书?数据结构是:1.数据对象在计算机中的组织方式;2.数据对象必定与一系列加在其上的操作相关联;3.完成这些操作所用的方法就是算法。抽象数据类型数据类型-数据对象集;-数据集合相关联的操作集。抽象-与存放数据的机器无关;-与数据存储的物理结构无关;-与实现操作的算法和编程语言均无关。

  4. 陈越《数据结构》第二章 线性结构

    表中元素个数称为线性表的长度;线性表没有元素时,称为空表;表起始位置称表头,表结束位置称表尾。插入和删除操作只能在链栈的栈顶进行。

  5. 【数据结构】

    非线性结构:线性结构的元素之间具有线性关系,非线性结构中的元素之间不再是序列的关系,他们呈现的是更复杂的层次关系,即一个数据元素有且仅有一个直接前驱,但可有另个或者多个直接后继,显然比序列关系复杂常见非线性结构:树,图散列表PHP中的hashtable就是哈希表就是由数组和链表组成,一个长度为16的数组中,每个元素存储的是一个链表的头结点。

  6. 【数据结构】【C++STL】FIFO队列&amp;优先队列

    首先都需要打头文件queueFIFO队列是先进先出的就好像排队一样STL定义FIFO队列优先队列的话是有优先级存在的STL定义优先队列定义方式都是大根堆FIFO队列和优先队列都有一些操作COYG

  7. 【数据结构】 堆

    自底向上://增加/减少已有节点值Heap_Increase_Key//向堆插入新的节点HeapInsert自顶向下://替换堆顶后,维持堆函数KeepHeap//弹出堆顶函数Pop

  8. 【数据结构】链表

    线性表的顺序存储结构有存储密度高及能够随机存取等优点,但存在以下不足:线性表的链式存储(单链表)的实现单向循环链表的实现

  9. 伸展树(SPLAY)个人总结+模板 [平衡树]【数据结构】【模板】

    前言最近3个月内,无论是现场赛还线上赛中SPLAY出现的概率大的惊人啊啊啊!!!然而不会的我就GG了,同时发现大家都会SPLAY,,,,然后就学习了一波。——————————————————————————-附上整体代码-md贴上来太卡了,去题解里看吧维护序列的维护一堆数的

  10. BZOJ 1895 &amp; POJ 3580 supermemo [SPLAY]【数据结构】

    Ay}Ttimes.Forexample,performing“REVOLVE242”on{1,5}INSERTxP:insertPafterAx.Forexample,performing“INSERT24”on{1,5}DELETEx:deleteAx.Forexample,performing“DELETE2”on{1,5}MINxy:querytheparticipantwhatistheminimumnumberinsub-sequence{Ax…Ay}.Forexample,thecorrec

返回
顶部