顺序栈——栈的顺序存储结构
栈属于特殊的线性表,支持进栈出栈判空判满等基础操作。
可以利用数组模拟栈搭配top值进行以上的基础操作。
两栈共享空间(双端栈) :
在一个程序中需要同时使用具有相同数据类型的两个栈,可以为这两个栈用数组模拟创建共享空间,称为双向栈。
两栈共享空间:
使用一个数组来存储两个栈,让一个栈的栈底为该数组的始端,另一个栈的栈底为该数组的末端,两个栈从各自的端点向中间延伸。
插入:
if (top1==top2-1)
throw "上溢";
if (i==1)
data[++top1]=x;
if (i==2)
data[--top2]=x;
栈的链式存储结构及实现
将链头作为栈顶,方便操作。链栈不需要附设头结点。
链栈的实现——插入(入栈)
template <class T>
void LinkStack<T>::Push(T x)
{
s=new Node<T>;
s->data=x;
s->next=top;
top=s;
}
链栈的实现——删除(出栈)
template <class T>
T LinkStack<T>::Pop( )
{
if (top==NULL)
throw "下溢";
x=top->data;
p=top;
top=top->next;
delete p;
return x;
}
顺序栈和链栈的比较:
时间性能:相同,都是常数时间O(1)。
空间性能:
顺序栈:有元素个数的限制和空间浪费的问题。
链栈:没有栈满的问题,只有当内存没有可用空间时才会出现栈满,但是每个元素都需要一个指针域,从而产生了结构性开销。
结论:
当栈的使用过程中元素个数变化较大时,用链栈是适宜的,反之,应该采用顺序栈。