问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

分别就栈的顺序存储结构和链式存储结构实现栈的各种基本操作。_百度知 ...

发布网友 发布时间:2022-04-24 08:29

我来回答

2个回答

热心网友 时间:2022-04-22 16:48

顺序存储结构

#include<iostream>
typedef char ElemType;
#define MaxSize 100
using namespace std;
typedef struct
{
ElemType data[MaxSize];
int top;
}sqStack;
void InitStack(sqStack *&s);//初始化栈
void ClearStack(sqStack *&s);//摧毁栈
int StackLength(sqStack *s);//返回栈的长度
bool StackEmpty(sqStack *s);//判断栈是否为空
int Push(sqStack *&s,ElemType e);//进栈
int Pop(sqStack *&s,ElemType &e);//出栈
int GetTop(sqStack *s,ElemType &e);//取栈顶元素
void DispStack(sqStack *s);//显示栈中元素值
int main()
{

return 0;
}

void InitStack(sqStack *&s)//初始化栈
{
s=new sqStack;
s->top=-1;
}
void ClearStack(sqStack *&s)//摧毁栈
{
delete s;
}

int StackLength(sqStack *s)//返回栈的长度
{
return (s->top+1);
}

bool StackEmpty(sqStack *s)//判断栈是否为空
{
return (s->top==-1);
}

int Push(sqStack *&s,ElemType e)//进栈
{
if(s->top==MaxSize-1)
return 0;
s->top++;
s->data[s->top]=e;
return 1;
}

int Pop(sqStack *&s,ElemType &e)//出栈
{
if(s->top==-1)
return 0;
e=s->data[s->top];
s->top--;
return 1;

}

int GetTop(sqStack *s,ElemType &e)//取栈顶元素
{
if(s->top==-1)
return 0;
e=s->data[s->top];
return 1;
}

void DispStack(sqStack *s)//显示栈中元素值
{
for(int i=s->top;i>=0;i--)
cout<<s->data[i]<<" ";
cout<<endl;
}

链式存储结构

typedef char ElemType;

typedef struct linknode
{
ElemType data;
struct linknode *next;
}LiStack;
void InitStack(LiStack *&s);//初始化栈
void ClearStack(LiStack *&s);//摧毁栈
int StackLength(LiStack *s);//返回栈的长度
bool StackEmpty(LiStack *s);//判断栈是否为空
void Push(LiStack *&s,ElemType e);//进栈
int Pop(LiStack *&s,ElemType &e);//出栈
int GetTop(LiStack *s,ElemType &e);//取栈顶元素
void DispStack(LiStack *s);//显示栈中元素值

int main()
{
return 0;
}

void InitStack(LiStack *&s)//初始化栈
{
s=new LiStack;
s->next=NULL;
}

void ClearStack(LiStack *&s)//摧毁栈
{
for(LiStack *p=s->next;p;p=p->next)
{
delete s;
s=p;
p=p->next;
}
delete s;
}

int StackLength(LiStack *s)//返回栈的长度
{
int i=0;
for(LiStack *p=s->next;p;p=p->next)
i++;
return i;
}

bool StackEmpty(LiStack *s)//判断栈是否为空
{
return (s->next==NULL);
}

void Push(LiStack *&s,ElemType e)//进栈
{
LiStack *p=new LiStack;
p->data=e;
p->next=s->next;
s->next=p;
}

int Pop(LiStack *&s,ElemType &e)//出栈
{
LiStack *p;
if(s->next==NULL)
return 0;
p=s->next;
e=p->data;
s->next=p->next;
delete p;
return 1;

}
int GetTop(LiStack *s,ElemType &e)//取栈顶元素
{
if(s->next==NULL)
return 0;
e=s->next->data;
return 1;
}
void DispStack(LiStack *s)//显示栈中元素值
{
LiStack *p=s->next;
for(;p;p=p->next)
cout<<p->data<<" ";
cout<<endl;

}

热心网友 时间:2022-04-22 18:06

一、顺序栈
栈的顺序存储结构简称为顺序栈,它是运算受限的顺序表。因此,可用数组来实现顺序栈。
因为栈底位置是固定不变的,所以可以将栈底位置设置在数组的两端的任何一个端点;
栈顶位置是随着进栈和退栈操作而变化的.

栈的顺序存储表示 — 顺序栈

#include <assert.h>
template <class Type> class Stack {
private:
int top; //栈顶数组指针
Type *elements; //栈数组
int maxSize; //栈最大容量
public:
Stack ( int=10 ); //构造函数
~Stack ( ) { delete[ ] elements; }//析构函数

void Push ( const Type & item ); //入栈
Type Pop ( ); //出栈
Type GetTop ( ); //取栈顶元素
void MakeEmpty ( ) { top=-1; } //置空栈
int IsEmpty ( ) const { return top == -1; }
int IsFull ( ) const
{ return top == maxSize-1; }

}
void Push ( const Type & item ); //入栈
Type Pop ( ); //出栈
Type GetTop ( ); //取栈顶元素
void MakeEmpty ( ) { top=-1; } //置空栈
int IsEmpty ( ) const { return top == -1; }
int IsFull ( ) const
{ return top == maxSize-1; }

}
构造函数
template <class Type> Stack<Type>::
Stack ( int s ) : top (-1), maxSize (s) {
elements = new Type[maxSize];
}
template <class Type> void Stack<Type>::
Push ( const Type & item ) {
assert ( !IsFull ( ) );或//先决条件断言
if(top != maxSize-1 )
elements[++top] = item; //加入新元素
}
template <class Type> Type Stack<Type>:: Pop ( ) {
assert ( !IsEmpty ( ) ); //先决条件断言
return elements[top--]; //退出栈顶元素
}
template <class Type> Type stack<Type>::
GetTop ( ) {
assert ( !IsEmpty ( ) ); //先决条件断言
return elements[top]; //取出栈顶元素
}

链式栈 (LinkedStack)类的定义

template <class Type> class Stack;
template <class Type> class StackNode {
friend class Stack<Type>;
private:
Type data; //结点数据
StackNode<Type> *link; //结点链指针
StackNode ( Type d=0, StackNode<Type>
*l=NULL ) : data (d), link (l) { }
};
template <class Type> class Stack {
private:
StackNode<Type> *top; //栈顶指针public:
Stack ( ) : top ( NULL ) { }
~Stack ( );
void Push ( const Type & item);
Type Pop ( );
Type GetTop ( );
void MakeEmpty ( ) ;
int IsEmpty ( ) const
{ return top == NULL; }
}
template <class Type> void Stack<Type>::
~Stack ( ) {
StackNode <Type> *p;
while ( top != NULL ) //逐结点回收
{ p = top; top = top→link; delete p; }
}
template <class Type> void Stack<Type>::
Push ( const Type &item ) { //入栈
top = new StackNode<Type> ( item, top );
//新结点链入top之前, 并成为新栈顶
}
template <class Type> Type Stack<Type>::
Pop ( ) { //出栈
assert ( !IsEmpty ( ) );或
if(top){
StackNode<Type> *p = top;
Type retvalue = p→data; //暂存栈顶数据
top = top→link; //修改栈顶指针
delete p; //释放空间
return retvalue; //返回数据
}//if
}
template <class Type> Type Stack<Type>::
GetTop ( ) { //取栈顶元素
assert ( !IsEmpty ( ) );
return top→data;
}
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
64岁的老头感冒了,还喝一瓶啤酒,又喝3包感冒药,吃了3个阿莫西林消炎药... ...今天中午12点喝了一瓶啤酒,不会有反应死了吧? 喝一瓶啤酒吃药没事吧 养育孩子有哪些正确的方式? 联想电脑一开机就蓝屏怎么解决 光遇冥想任务怎么完成_冥想任务攻略 光遇 光遇云野的锦鲤池冥想怎么做? 光遇 光遇在滑冰场旁冥想的任务怎么做? 光遇在仙乡的金塔下冥想任务怎么做 任务达成方法介绍 光遇 光遇在禁阁的神坛旁冥想怎么做? 线性表的链式存储结构定义及基本操作 二叉树通常链式结构还有什么结构 线性表链式存储结构的优点和缺点有什么? 线性表的链式存储结构主要包括哪三种形式。在线等。。。 链式存储结构的特点是利用什么来表示数据元素之间的逻辑关系? 存储结构有哪些? 笔记本电脑怎么投屏到lg c7上 笔记本LG屏幕 lg笔记本电脑显示屏用着怎么样谁知道 LG显示器连接笔记本 惠普笔记本用的是LG的显示器 质量怎么样啊? 宝宝注意力不集中,该做哪些训练改善呢? 外卖小哥电话? 外卖电话 为什么年底要账难度越来越大 年底了,客户不给结账,怎么讨账?讨账有几种方法? 过年讨债的经典台词 美团外卖人工客服电话是多少? 要过年了!怎么去要账啊?我又不好意思去要的! 怎么要账不得罪人 线性表的链式存储结构是一种()存储结构? 链式存储结构的特点是利用什么来表示数据元素之间的逻辑关系 数据结构,树的常用存储方式 链式队列存储结构的定义及基本操作 数据结构线性表的单链表存储结构 百度网盘文件显示网页转存的意思 百度云转存文件 在百度网盘买的课程每次都让转存有什么用? 为什么从百度云转存微云的文件老是提示云端转存中 百度网盘下载和转存有啥区别? 百度网盘转存不了是什么原因? 115网盘上传文件后显示待续传,是什么意思?还有提取文件时显示文件转存中,请稍后下载又是什么意思? 百度网盘转存不了文件,什么原因 百度云盘文件怎么转存到另一个百度网盘里 什么叫转存到网盘 网盘是什么意思 自己要申请吗?存到网盘以后用起来方便吗? 百度网盘在升级中是什么意思 果绿色厚窗帘布配啥色杆子好看? 什么颜色的布或什么样的布料挡太阳光或遮荫效果比较好? 小米蓝牙共享网络是什么意思,可以通过台式电脑蓝牙连接小米手机wifi上网吗? 台式电脑不知道wifi密码,怎么连wifi