栈的链式存储(包括栈的初始化,进栈,出栈,判空等等)

#include <iostream>

using namespace std;

typedef int ElemType;

typedef struct Linknode

{

ElemType data;

struct Linknode* next;

}*LiStack;

LiStack initLiStack(LiStack& S);

void printLiStack(LiStack& S);

LiStack AddLiStack(LiStack& S, int& n);

LiStack deleteLiStack(LiStack& S, int& n);

int main()

{

LiStack S;

int n = 0;

initLiStack(S);

AddLiStack(S, n);

printLiStack(S);

deleteLiStack(S,n);

printLiStack(S);

system("pause");

return 0;

}

//链栈初始化

LiStack initLiStack(LiStack &S)

{

S = NULL;

return S;

}

//增加栈中元素(进栈)

LiStack AddLiStack(LiStack& S,int &n)

{

LiStack p;

p = S;

ElemType e = 0;

int i;

cout << "请输入进栈元素个数:" << endl;

cin >> i;

cout << "请依次输入增加的元素:" << endl;

while (i!=0)

{

cin >> e;

p = new struct Linknode;

p->data = e;

if (S == NULL)

p->next = NULL;

else

p->next = S;

S = p;

i--;

n++;

}

cout << "进栈成功: " << endl;

return S;

}

//显示栈中元素

void printLiStack(LiStack& S)

{

LiStack q;

q = S;

if (q)

{

cout << "栈中的元素为:" << endl;

while (q)

{

cout << q->data << " ";

q = q->next;

}

cout << endl;

}

else

{

cout << "此链栈为空:" << endl;

}

}

//删除栈中元素(出栈)

LiStack deleteLiStack(LiStack& S,ElemType &n)

{

LiStack q;

cout << "请输入出栈元素个数:" << endl;

int i;

cin >> i;

while (i>n)

{

cout << "输入数据有误,请输入小于等于栈中元素个数" << n << "的值" << endl;

cin >> i;

}

while (i != 0)

{

q = S;

S = S->next;

delete q;

q = NULL;

i--;

n--;

}

cout << "出栈成功:" << endl;

return S;

}

bool IsEmptyListack(LiStack& S)

{

if (S == NULL)

return false;

else

return true;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值