将栈(一)的内容改写为长尾词,如何表达?
- 内容介绍
- 文章标签
- 相关推荐
本文共计824个文字,预计阅读时间需要4分钟。
栈的实现与优缺点:栈的实现通常可以使用数组或链表。使用数组实现的栈在空间效率上更优,因为数组在内存中是连续分配的,而链表则需要额外的空间来存储指针。相对而言,数组栈在插入数据时的性能更佳,因为不需要动态分配内存。然而,数组栈的缺点是容量固定,当栈满时需要重新分配更大的数组空间,这会导致性能下降。链表栈则可以动态调整大小,但插入操作需要额外的指针操作,可能会影响性能。
动态数组实现栈时,遇到的主要问题是容量不足时需要扩容。扩容通常涉及到创建一个新的更大的数组,然后将旧数组中的元素复制到新数组中,这会引入一定的性能开销。而链表栈则不存在这个问题,因为它可以根据需要动态增加节点。
总之,使用数组实现的栈在空间和性能上有优势,但容量固定;而链表栈在动态调整大小上更灵活,但可能在性能上稍逊一筹。
栈的实现
栈的实现一般可以使用数组或者链表实现,相对而言数组的结构实现更优一些,因为数组在尾上插入数据的代价比较小。用动态数组实现时唯一的缺陷就是需要扩容;也可以使用单链表实现,单链表的头插头删更方便,所以单链表的头可以当作栈顶,单链表的尾可以当作栈底。本篇文章采用的是动态开辟的数组实现对栈的基本操作。 定义结构体:
typedef int STDataType;
typedef struct Stack {
STDataType* arr;
int top;//栈顶元素的下一个坐标
int capacity;//数组容量
}ST;
1.初始化栈
void StackInit(ST* ps)//初始化栈
{
assert(ps);//避免传过来的地址为空
STDataType* tmp = (STDataType*)malloc(sizeof(STDataType*)*4);
if (tmp == NULL)
{
perror("malloc");
exit(-1);
}
ps->arr = tmp;
ps->top = 0;
ps->capacity = 4;
}
初始化栈时必须要断言,避免穿过来的指针为空,同时也避免了当定义变量为
ST* st=NULL;对其进行初识化StackInit(st)这种情况的发生。top初始化为0,表示指向栈顶元素的下一个位置,也可以表示栈中的元素个数;top初始化为-1,表示指向栈顶元素。
2.压栈
void StackPush(ST* ps, STDataType x)//压栈
{
assert(ps);
//判断是否需要扩容
if (ps->capacity == ps->top)
{
STDataType* tmp = (STDataType*)realloc(ps->arr, sizeof(STDataType*) * 2 * ps->capacity);//扩容
if (tmp == NULL)
{
perror("realloc");
exit(-1);
}
ps->arr = tmp;
ps->capacity = 2 * ps->capacity;
}
ps->arr[ps->top] = x;
ps->top++;
}
压栈时要检查数组是否已满,是否需要对其进行扩容。
本文共计824个文字,预计阅读时间需要4分钟。
栈的实现与优缺点:栈的实现通常可以使用数组或链表。使用数组实现的栈在空间效率上更优,因为数组在内存中是连续分配的,而链表则需要额外的空间来存储指针。相对而言,数组栈在插入数据时的性能更佳,因为不需要动态分配内存。然而,数组栈的缺点是容量固定,当栈满时需要重新分配更大的数组空间,这会导致性能下降。链表栈则可以动态调整大小,但插入操作需要额外的指针操作,可能会影响性能。
动态数组实现栈时,遇到的主要问题是容量不足时需要扩容。扩容通常涉及到创建一个新的更大的数组,然后将旧数组中的元素复制到新数组中,这会引入一定的性能开销。而链表栈则不存在这个问题,因为它可以根据需要动态增加节点。
总之,使用数组实现的栈在空间和性能上有优势,但容量固定;而链表栈在动态调整大小上更灵活,但可能在性能上稍逊一筹。
栈的实现
栈的实现一般可以使用数组或者链表实现,相对而言数组的结构实现更优一些,因为数组在尾上插入数据的代价比较小。用动态数组实现时唯一的缺陷就是需要扩容;也可以使用单链表实现,单链表的头插头删更方便,所以单链表的头可以当作栈顶,单链表的尾可以当作栈底。本篇文章采用的是动态开辟的数组实现对栈的基本操作。 定义结构体:
typedef int STDataType;
typedef struct Stack {
STDataType* arr;
int top;//栈顶元素的下一个坐标
int capacity;//数组容量
}ST;
1.初始化栈
void StackInit(ST* ps)//初始化栈
{
assert(ps);//避免传过来的地址为空
STDataType* tmp = (STDataType*)malloc(sizeof(STDataType*)*4);
if (tmp == NULL)
{
perror("malloc");
exit(-1);
}
ps->arr = tmp;
ps->top = 0;
ps->capacity = 4;
}
初始化栈时必须要断言,避免穿过来的指针为空,同时也避免了当定义变量为
ST* st=NULL;对其进行初识化StackInit(st)这种情况的发生。top初始化为0,表示指向栈顶元素的下一个位置,也可以表示栈中的元素个数;top初始化为-1,表示指向栈顶元素。
2.压栈
void StackPush(ST* ps, STDataType x)//压栈
{
assert(ps);
//判断是否需要扩容
if (ps->capacity == ps->top)
{
STDataType* tmp = (STDataType*)realloc(ps->arr, sizeof(STDataType*) * 2 * ps->capacity);//扩容
if (tmp == NULL)
{
perror("realloc");
exit(-1);
}
ps->arr = tmp;
ps->capacity = 2 * ps->capacity;
}
ps->arr[ps->top] = x;
ps->top++;
}
压栈时要检查数组是否已满,是否需要对其进行扩容。

