【数据结构】栈的实现——顺序栈和链栈

【一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义】

**开源地址:https://docs.qq.com/doc/DSmxTbFJ1cmN1R2dB **

if(isEmpty()){

throw Stack::Empty();

}else{

return data[top–];

}

}

//得到栈顶元素 不弹出

template DataType Stack::getTop(){

if(isEmpty()){

throw Stack::Empty();

}else{

return data[top];

}

}

//栈的长度

template int Stack::length(){

return top+1;

}

//将栈清空

template void Stack::setNull(){

top=-1;

}

template class Stack;

template class Stack;

//主函数

#include

#include “Stack.h”

#include “Sta.cpp”

using namespace std;

//顺序栈

int main(){

CharStack charStack;

IntStack intStack(3);

try{

intStack.push(2);

intStack.push(60);

intStack.push(100);

cout<<“栈的长度:”<<intStack.length()<<endl;

}catch(IntStack::Full){

cout<<“STACK FULL!”<<endl;

}

try{

intStack.pop();

}catch(IntStack::Empty){

cout<<“STACK EMPTY!”<<endl;

}

cout<<“栈的长度:”<<intStack.length()<<endl;

return 0;

}

三、链栈


基于链表实现(不带头节点)

在这里插入图片描述

#ifndef LINKSTACK_H_INCLUDED

#define LINKSTACK_H_INCLUDED

template

struct Node{

DataType data; //数据域

Node *next; //指针域

};

template

class LinkStack{

private:

Node *top; //栈顶指针

public:

LinkStack();

~LinkStack();

void push(DataType x);

DataType pop();

DataType getTop();

bool isEmpty();

bool isFull();

};

typedef LinkStack CharLinkStack;

typedef LinkStack IntLinkStack;

#endif // LINKSTACK_H_INCLUDED

#include “LinkStack.h”

//构造函数 创建top指针

template LinkStack::LinkStack(){

top=NULL;

}

//析构函数 释放资源

template LinkStack::~LinkStack(){

Node *p=NULL;

while(top!=NULL){

p=top->next;

delete top;

top=p;

}

}

//判断链栈是否为空

template bool LinkStack::isEmpty(){

if(top==NULL){

return true;

}else{

return false;

}

}

/*template bool LinkeStack::isFull(){

}*/

//压入元素

template void LinkStack::push(DataType x){

Node *s=new Node; //新定义一个Node结点指针

s->data=x;

s->next=top; //将结点的指针域指向栈顶top(即压入了一个新的元素)

top=s; //再让top指向结点

}

//弹出栈顶元素

template DataType LinkStack::pop(){

if(isEmpty()){

throw “链栈为空,无法弹出元素”;

}else{

DataType x=top->data;

Node *p=new Node;

p=top; //将栈顶指针先赋给p

top=top->next; //栈顶指针指向栈顶的下一个存储空间(即栈顶元素弹出)

delete p; //销毁p的空间

return x;

}

}

//返回栈顶元素

template DataType LinkStack::getTop(){

return top->data;

}

template class LinkStack;

template class LinkStack;

#include

#include “LinkStack.cpp”

using namespace std;

//链栈

int main()

{

IntLinkStack intLinkStack;

intLinkStack.push(20);

intLinkStack.push(15);

cout<<“栈顶元素:”<<intLinkStack.getTop()<<endl;

intLinkStack.pop();

cout<<“栈顶元素:”<<intLinkStack.getTop()<<endl;

return 0;

}

注意:

  • C++分文件编写时需要在   .h中尾部加入代码,相当于为每个类型的模板定义了一个类型
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值