ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

王道-考研-数据结构-栈【stack】

2022-09-10 20:33:42  阅读:211  来源: 互联网

标签:return SqStack top next bool 数据结构 data stack 考研


栈和队列

三要素:

  1. 逻辑结构
  2. 数据的运算
  3. 存储结构(物理结构)

栈和队列都是操作受限的线性表。

1.1. 定义

栈是只允许在一端进行插入或删除操作的线性表。

  • 栈顶:允许插入和删除的一端。
  • 栈底:不允许插入和删除的一端。
  • 空栈
  • 栈顶元素
  • 栈底元素

进栈顺序:

\[a_1->a_2->a_3->a_4->a_5 \]

出栈顺序:

\[a_5->a_4->a_3->a_2->a_1 \]

后进先出,Last In First OUT(LIFO)

1.2. 基本操作

  • InitStack(&S):初始化栈。构造一个空栈 \(S\),分配内存空间。
  • DestroyStack(&S):销毁栈。销毁并释放栈 \(S\) 所占用的内存空间。
  • Push(&S, x):进栈。若栈 \(S\) 未满,则将 \(x\) 加入使之成为新栈顶。
  • Pop(&S, &x):出栈,若栈 \(S\) 非空,则弹出栈顶元素,并用 \(x\) 返回。
  • GetTop(S, &x):读栈顶元素。若栈 \(S\) 非空,则用 \(x\) 返回栈顶元素。
  • StackEmpty(S):判断一个栈 \(S\) 是否为空。若 \(S\) 为空,则返回 true,否则返回 false

\(n\) 个不同的元素进栈,出栈元素的不同排列的个数为:

\[\frac{1}{n+1} C^{n}_{2n} \]

上述公式称为 卡特兰(Catalan)数。可采用数学归纳法证明(不要求掌握)。

\[\frac{1}{5+1} C^{5}_{10} =\frac{10 \times 9 \times 8 \times 7 \times 6}{6 \times 5 \times 4 \times 3 \times 2 \times 1} =42 \]

1. 顺序栈

1.1. 定义

用顺序存储方式实现的栈。

#define MaxSize 10
typedef struct
{
    ElemType data[MaxSize];
    int top; // 栈顶指针
} SqStack;

\(MaxSize*sizeof(ElemType)+4B\)

1.2. 初始化栈

// 初始化栈
void InitStack(SqStack &S)
{
    S.top = -1;
}
// 判断栈空
bool StackEmpty(SqStack S)
{
    return S.top == -1;
}
// 判断栈满
bool StackFull(SqStack S)
{
    return S.top == MaxSize - 1;
}

1.3. 进栈

// 进栈
bool Push(SqStack &S, int x)
{
    if (StackFull(S))
    {
        return false;
    }
    // S.top++;
    // S.data[S.top] = x;
    S.data[++S.top] = x;
    return true;
}

1.4. 出栈

// 出栈,数据还残留在内存中,只是逻辑上被删除了
bool Pop(SqStack &S, int &x)
{
    if (StackEmpty(S))
    {
        return false;
    }
    // x = S.data[S.top];
    // S.top--;
    x = S.data[S.top--];
    return true;
}

1.5. 获取栈顶元素

// 读取栈顶元素
bool GetTop(SqStack &S, int &x)
{
    if (StackEmpty(S))
    {
        return false;
    }
    x = S.data[S.top];
    return true;
}

1.6. 另一种初始化栈的方式

// 初始化栈
void InitStack(SqStack &S)
{
    S.top = 0;
}
// 判断栈空
bool StackEmpty(SqStack S)
{
    return S.top == 0;
}
// 判断栈满
bool StackFull(SqStack S)
{
    return S.top == MaxSize;
}

1.7. 顺序栈的缺点

栈的大小不可改变。

1.8. 共享栈

两个栈共享同一片内存空间,两个栈从两边往中间增长。

#define MaxSize 10
typedef struct
{
    ElemType data[MaxSize];
    int top0;
    int top1;
} ShStack;
// 初始化共享栈
void InitStack(ShStack &S)
{
    S.top0 = -1;
    S.top1 = MaxSize;
}
// 判断栈满
bool StackFull(ShStack S)
{
    return S.top0 + 1 == S.top1;
}

2. 链栈

2.1. 定义

typedef struct LNode
{
    ElemType data;
    struct LNode *next;
} LNode, *LinkStack;

2.2. 初始化

// 初始化一个链栈,带头结点
bool InitStack(LinkStack &S)
{
    S = (LNode *)malloc(sizeof(LNode));
    if (S == NULL)
    {
        return false;
    }
    S->next = NULL;
    return true;
}
// 判断栈空
bool StackEmpty(LinkStack S)
{
    return S->next == NULL;
}

2.3. 进栈

// 进栈
bool Push(LinkStack &S, int x)
{
    LNode *s = (LNode *)malloc(sizeof(LNode));
    s->data = x;
    s->next = S->next;
    S->next = s;
    return true;
}

2.4. 出栈

// 出栈
bool Pop(LinkStack &S, int &x)
{
    if (StackEmpty(S))
    {
        return false;
    }
    LNode *q = S->next;
    x = q->data;
    S->next = q->next;
    free(q);
    return true;
}

2.5. 获取栈顶元素

// 读取栈顶元素
bool GetTop(LinkStack &S, int &x)
{
    if (StackEmpty(S))
    {
        return false;
    }
    x = S->next->data;
    return true;
}

标签:return,SqStack,top,next,bool,数据结构,data,stack,考研
来源: https://www.cnblogs.com/bi-hu/p/16678255.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有