请教一个问题!希望师兄们帮帮忙!!

xfxf521 2004-08-26 10:54:33
这是书本上一道习题!!
编写一个类,实现一个简单的栈!!
成员函数为:void stack::put(int item);
int stack::get();
数据成员为:
一个指向链首的指针
链表结构为:
strcut Node
{ int a;
Node *next;
};
...全文
109 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
Lonelywolf1899 2004-08-27
  • 打赏
  • 举报
回复
哈哈,我们当年的考试题目就是这个
hsz8250 2004-08-26
  • 打赏
  • 举报
回复
应该多看看数据结构~
ntxs 2004-08-26
  • 打赏
  • 举报
回复
基于链表的。
链表你应该会了吧。
只在一端插入删除 就是你要的功能了
snow810211 2004-08-26
  • 打赏
  • 举报
回复
哈哈~~兄弟,我知道,这是钱能书上的259页的习题~我也刚看完~~~
答案给你:
//stack.h
struct Node{
int a;
Node* next;
};

class Stack{
public:
Stack();
~Stack();
void Put(int item);
int Get();
protected:
Node* head;
};
//stack.cpp

#include "stack.h"
#include <stdlib.h>
#include <iostream.h>

Stack::Stack():head(NULL){}
void Stack::Put(int item)
{
Node* p = new Node;
p->a = item;
p->next = head;
head = p;
}

Stack::~Stack()
{
for(Node* p=head; p;){
Node* t = p;
p=p->next;
delete t;
}
}

int Stack::Get()
{
if(!head){
cerr <<"error access stack underflow.\n";
exit(1);
}
int result = head->a;
Node* p = head;
head = head->next;
delete p;
return result;
}
//11_5

#include <iostream.h>
#include "stack.h"

void main()
{
Stack sta;

sta.Put(10);
sta.Put(12);
sta.Put(14);

cout <<sta.Get() <<endl;
cout <<sta.Get() <<endl;
}
一个头文件,一个函数定义,一个是主程序~~~
zhangfjj 2004-08-26
  • 打赏
  • 举报
回复
书上现成的,看书吧!
自己写

64,649

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧