C++利用链表写一个简单的栈实例详解

C++利用链表写一个简单的栈实例详解,第1张

概述C++中其实有stack的模板类。功能更为强大。自己写一个栈能让我们对栈这种数据结构更加熟悉。这个栈有一个不足之处就是里面存放的元素类型只能为int。

C++中其实有stack的模板类。功能更为强大。

自己写一个栈能让我们对栈这种数据结构更加熟悉。这个栈有一个不足之处就是里面存放的元素类型只能为int。

#include <iostream>using namespace std;class Stack{private:  struct Node  {    int data;    Node *next;  };  Node *head;  Node *p;  int length;public:  Stack()  {    head = NulL;    length = 0;  }  voID push(int n)//入栈  {    Node *q = new Node;    q->data = n;    if (head == NulL)    {      q->next = head;      head = q;      p = q;    }    else    {      q->next = p;      p = q;    }    length ++;  }  int pop()//出栈并且将出栈的元素返回  {    if (length <= 0)    {      abort();    }    Node *q;    int data;    q = p;    data = p->data;    p = p->next;    delete(q);    length --;    return data;  }  int size()//返回元素个数  {    return length;  }  int top()//返回栈顶元素  {    return p->data;  }  bool isEmpty()//判断栈是不是空的  {    if (length == 0)    {      return true;    }    else    {      return false;    }  }  voID clear()//清空栈中的所有元素  {    if (length > 0)    {      pop();    }  }};int main(){  //以下为测试代码  Stack s;  s.push(1);  s.push(2);  s.push(3);  while(!s.isEmpty())  {    cout<<s.pop()<<endl;  }  return 0;}

对这段代码稍加修改,这个栈就能存放其他类型的元素

#include <iostream>using namespace std;template<class T>class Stack{private:  struct Node  {    T data;    Node *next;  };  Node *head;  Node *p;  int length;public:  Stack()  {    head = NulL;    length = 0;  }  voID push(T n)//入栈  {    Node *q = new Node;    q->data = n;    if (head == NulL)    {      q->next = head;      head = q;      p = q;    }    else    {      q->next = p;      p = q;    }    length ++;  }  T pop()//出栈并且将出栈的元素返回  {    if (length <= 0)    {      abort();    }    Node *q;    int data;    q = p;    data = p->data;    p = p->next;    delete(q);    length --;    return data;  }  int size()//返回元素个数  {    return length;  }  T top()//返回栈顶元素  {    return p->data;  }  bool isEmpty()//判断栈是不是空的  {    if (length == 0)    {      return true;    }    else    {      return false;    }  }  voID clear()//清空栈中的所有元素  {    while(length > 0)    {      pop();    }  }};int main(){  Stack<char> s;  s.push('a');  s.push('b');  s.push('c');  while(!s.isEmpty())  {    cout<<s.pop()<<endl;  }  return 0;}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

总结

以上是内存溢出为你收集整理的C++利用链表写一个简单的栈实例详解全部内容,希望文章能够帮你解决C++利用链表写一个简单的栈实例详解所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/langs/1245032.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-07
下一篇2022-06-07

发表评论

登录后才能评论

评论列表(0条)

    保存