带链的栈的实现和操作

这个是用链表实现的栈,具体不想多说,直接看代码。

先写linked_Stack.h

#include
using namespace std;
template 
struct node{
T d;
node *next;
};

template 
class linked_Stack{
	private:
		node *top;
	public:
		linked_Stack();
		void prt_linked_Stack();
		int flag_linked_Stack();
		void ins_linked_Stack(T);
		T del_linked_Stack();
		T read_linked_Stack();
};

template 
linked_Stack::linked_Stack(){
	top=NULL;
	return;
}

template 
void linked_Stack::prt_linked_Stack(){
node *p;
p=top;
if(p==NULL){cout<<"Empty stack!"<d<next;
}while(p!=NULL);
return ;
}

template 
int linked_Stack::flag_linked_Stack(){
	if(top==0)return 0;
	return 1;
}

template 
void linked_Stack::ins_linked_Stack(T x){
	node *p;
	p=new node;
	p->d=x;
	p->next=top;
	top=p;
	return;
}

template 
T linked_Stack::del_linked_Stack(){
	T y;
	node *q;
	if(top==NULL){cout<<"Empty stack"<d;
	top=q->next;
	delete q;
	return y;
}

template 
T linked_Stack::read_linked_Stack(){
	if(top==NULL){cout<<"Empty stack"<d);
}
接着就是,linked_Stack_main.cpp
#include"linked_Stack.h"
int main(){
	linked_Stack s;
	s.ins_linked_Stack(50);
	s.ins_linked_Stack(60);
	s.ins_linked_Stack(70);
	s.ins_linked_Stack(80);
	s.ins_linked_Stack(90);
	s.ins_linked_Stack(100);
	cout <<"1 output the element:"<
其实,我在学这个链表的时候很是分不清楚,到底是谁指向了谁,尤其是等号,到底是左边付给了右边,还是所谓左边指向了右边,真的乱,怎么办?画个图,慢慢看,慢慢反应,简单说几句,关于插入,其实,就是新建一个点,那么它的指针域(所谓的)指向为head,那么head下次再指向当前的结点,那么就华丽的从以前的那个head变为现在这个位置上面的head,也许有些乱,好好想想;然后就是,删除,那么令当前的head为另外的一个节点,然后,删除它,让head指向当前的下一个指针域,从而此时head成为新的头结点,来来回回就是这么个过程,真的好好回忆一下就明白了。

最后,截个图

带链的栈的实现和操作_第1张图片


你可能感兴趣的:(数据结构)