当前位置: 首页> 科技> 互联网 > 【C++ Primer Plus习题】10.5

【C++ Primer Plus习题】10.5

时间:2025/7/12 10:03:53来源:https://blog.csdn.net/qq_74047911/article/details/141896234 浏览次数:0次

问题:

这里是引用

解答:
main.cpp

#include <iostream>
#include "Stack.h"
using namespace std;int main()
{Stack stack;customer cust;double sum_payment = 0;char select;cout << "a:入栈 p:出栈 q:退出";while (cin.get(select)&&select!='q'){while (cin.get() != '\n')continue;if (select == 'a'){cout << "请输入顾客的名字:";cin.getline(cust.fullname, 35);cout << "请输入顾客的支付:";cin >> cust.payment;while (cin.get() != '\n')continue;stack.push(cust);}if (select == 'p'){stack.pop(cust);sum_payment += cust.payment;cout << "出栈的顾客姓名:" << cust.fullname << endl;cout << "出栈的支付:" << cust.payment << endl;cout << "当前总支付为:" << sum_payment << endl;}cout << "a:入栈 p:出栈 q:退出";}cout << "Bye!" << endl;return 0;
}

Stack.h

#pragma oncestruct customer
{char fullname[35];double payment;
};typedef customer Item;class Stack
{
private:enum{MAX=10};Item items[MAX];int top;
public:Stack();bool isempty()const;bool isfull()const;bool push(const Item& item);bool pop(Item& item);
};

Stack.cpp

#include "Stack.h"
#include <iostream>
using namespace std;Stack::Stack()
{this->top = 0;
}
bool Stack::isempty()const
{return this->top == 0;
}
bool Stack::isfull()const
{return this->top == MAX;
}
bool Stack::push(const Item& item)
{if (this->isfull()){cout << "栈已满,无法入栈!" << endl;return false;}this->items[top++] = item;return true;
}
bool Stack::pop(Item& item)
{if (this->isempty()){cout << "栈为空,无法出栈!" << endl;return false;}item = this->items[--top];return true;
}

运行结果:
在这里插入图片描述

考查点:

  • 数据结构栈
  • 重类型定义typedef

2024年9月4日15:58:36

关键字:【C++ Primer Plus习题】10.5

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: