栈(链表)

文章目录

一种先存储的先输出的结构

属性:{1.栈头,2.栈尾,3.栈顶标志}

操作:
1.入栈 2.出栈 3.判断栈是否为空 4.获取栈顶元素

我们下面依次来实现
链表栈

#include<iostream>
using namespace std;

struct Node
{
	int data;
	Node* next;
};

class stack {
public:
	stack();//初始化
	Node* creatnewNode();//创建新节点
	void setinnewNode();//向栈顶堆栈
	int getfrist();//得到栈顶元素
	void createstack(int nun);//创建一个栈本身
	int removefrist();//出栈
	void showall();//遍历栈
private:
	Node* stacktop=new Node;
	int size;
};


void stack::createstack(int num) {
	for (int i = 0; i < num; i++) {
		setinnewNode();//有多少个数字我们就加多少次
	}
}

stack::stack() {
	stacktop->data = 0;
	stacktop->next = NULL;
	size = 0;
}

Node* stack::creatnewNode() {
	Node* p = new Node;//开一个新的节点
	p->data = 0;
	p->next = NULL;
	return p;
}

void stack::setinnewNode() {
	Node* newNode = stack::creatnewNode();
	newNode->next = stacktop->next;
	cout << "请输入新的数据。" << endl;
	int num=0;
	cin >> num;
	newNode->data = num;
	stacktop->next = newNode;
	size++;
}


 int stack::getfrist() {
	 return stacktop->next->data;
}

 int stack::removefrist() {
	 Node* temp = stacktop->next;
	 stacktop->next = stacktop->next->next;
	 int num = temp->data;
	 delete temp;
	 size--;
	 return num;
 }

 void stack::showall() {
	 if (size == 0) {
		 cout << "栈为空。";
	 }
	 Node* curr = stacktop->next;
	 for (int i = 0; i < size; i++) {
		 cout << curr->data;
		 curr = curr->next;
	 }
 }

int main() {
	stack A;
	A.createstack(5);
	A.showall();
	system("pause");
	return 0;

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值