接着说说友员
friend和操作符重载
operator,为了把这两个搞清楚,费了大半天劲儿搞了一个堆栈,被一堆指针问题搞得头都大了!
不过,最终还是OK了!
这次做这么一件事,搞体育活动。每个团队Team 有5个队员Comperitor ,可以对队员做入栈、出栈操作,每个队员有编号、名字。对输入队员信息、输出队员信息做操作符重载,使得输入的时候能够给出相应提示。
构建一个队员类Comperitor
/**
* 队员
*/
class Comperitor {
private:
char name[20]; //姓名
int id; //编号
public:
/**
* 取得ID
*/
int getId() {
return id;
}
/**
* 设置ID
*/
void setId(int id) {
this->id = id;
}
/**
* 取得名字
*/
char* getName() {
return name;
}
/**
* 设置名字
*/
void setName(char *name) {
strcpy(this->name, name);
}
/**
* 重载输入操作符
*/
friend istream & operator >>(istream & is, Comperitor & c) {
cout << "请输入您的编号: ";
is >> c.id;
cout << "请输入您的姓名: ";
is >> c.name;
return is;
}
/**
* 重载输出操作符
*/
friend ostream & operator <<(ostream & os, Comperitor & c) {
os << "编号: " << c.id << endl;
os << "姓名: " << c.name << endl;
return os;
}
};
为名字赋值的时候,name我们使用的是char数组,需要通过strcpy赋值。
/**
* 设置名字
*/
void setName(char *name) {
strcpy(this->name, name);
}
构建一个重载操作符,注意使用
&符号,引用方式,且操作符重载必须是友员方法!
/**
* 重载输入操作符
*/
friend istream & operator >>(istream & is, Comperitor & c) {
cout << "请输入您的编号: ";
is >> c.id;
cout << "请输入您的姓名: ";
is >> c.name;
return is;
}
构建一个团队类,用来控制入栈、出栈。
/**
* 团队
*/
class Team {
private:
/**
* 队员列表
*/
Comperitor *c[5];
/**
* 当前队列指针
*/
int pointer;
/**
* 队列上限
*/
int MAX;
/**
* 队列下限
*/
int MIN;
/**
* 是否为空
*/
bool empty;
/**
* 是否为满
*/
bool full;
public:
/**
* 空构造
*/
Team() {
MAX = 5;
MIN = 0;
pointer = MIN;
empty = false;
full = false;
}
/**
* 取得当前指针
*/
int getPointer() {
return pointer;
}
/**
* 队员入队
*/
void push() {
// 取得当前对象指针
Comperitor *com = new Comperitor;
// 输入
cin >> *com;
// 指向置为当前输入对象
c[pointer] = com;
// 当前指针自 加
pointer++;
// 指针复位
if (pointer >= MAX) {
// 将当前指针指向栈顶
pointer = MAX - 1;
// 置为栈满
full = true;
}
}
/**
* 队员出队
*/
void pop() {
// 取得当前对象指针
Comperitor *com = c[pointer];
// 输出
cout << *com;
// 指向置为空
c[pointer] = NULL;
// 当前指针自减
pointer--;
// 指针复位
if (pointer < MIN) {
// 置为栈空
empty = true;
// 将当前指针指向栈底
pointer = MIN;
}
}
/**
* 是否为空栈
*/
bool isEmpty() {
return empty;
}
/**
* 是否为满栈
*/
bool isFull() {
return full;
}
};
这里要用指针数组构建队员列表
/**
* 队员列表
*/
Comperitor *c[5];
关于指针的使用,我还解释不清楚,久远的过去了能将就用了!
看看整体的程序吧!
#include <iostream>
using namespace std;
/**
* 队员
*/
class Comperitor {
private:
char name[20]; //姓名
int id; //编号
public:
/**
* 取得ID
*/
int getId() {
return id;
}
/**
* 设置ID
*/
void setId(int id) {
this->id = id;
}
/**
* 取得名字
*/
char* getName() {
return name;
}
/**
* 设置名字
*/
void setName(char *name) {
strcpy(this->name, name);
}
/**
* 重载输入操作符
*/
friend istream & operator >>(istream & is, Comperitor & c) {
cout << "请输入您的编号: ";
is >> c.id;
cout << "请输入您的姓名: ";
is >> c.name;
return is;
}
/**
* 重载输出操作符
*/
friend ostream & operator <<(ostream & os, Comperitor & c) {
os << "编号: " << c.id << endl;
os << "姓名: " << c.name << endl;
return os;
}
};
/**
* 团队
*/
class Team {
private:
/**
* 队员列表
*/
Comperitor *c[5];
/**
* 当前队列指针
*/
int pointer;
/**
* 队列上限
*/
int MAX;
/**
* 队列下限
*/
int MIN;
/**
* 是否为空
*/
bool empty;
/**
* 是否为满
*/
bool full;
public:
/**
* 空构造
*/
Team() {
MAX = 5;
MIN = 0;
pointer = MIN;
empty = false;
full = false;
}
/**
* 取得当前指针
*/
int getPointer() {
return pointer;
}
/**
* 队员入队
*/
void push() {
// 取得当前对象指针
Comperitor *com = new Comperitor;
// 输入
cin >> *com;
// 指向置为当前输入对象
c[pointer] = com;
// 当前指针自 加
pointer++;
// 指针复位
if (pointer >= MAX) {
// 将当前指针指向栈顶
pointer = MAX - 1;
// 置为栈满
full = true;
}
}
/**
* 队员出队
*/
void pop() {
// 取得当前对象指针
Comperitor *com = c[pointer];
// 输出
cout << *com;
// 指向置为空
c[pointer] = NULL;
// 当前指针自减
pointer--;
// 指针复位
if (pointer < MIN) {
// 置为栈空
empty = true;
// 将当前指针指向栈底
pointer = MIN;
}
}
/**
* 是否为空栈
*/
bool isEmpty() {
return empty;
}
/**
* 是否为满栈
*/
bool isFull() {
return full;
}
};
/**
* 主函数
*/
int main() {
Team t;
cout << endl << "队员数据输入:" << endl;
int i = 1;
while (!t.isFull()) {
cout << "请输入第" << i << "位队员的信息:" << endl;
t.push();
i++;
};
cout << endl << "队员数据输出:" << endl;
int j = t.getPointer() + 1;
while (!t.isEmpty()) {
cout << "第" << j << "位队员的信息:" << endl;
t.pop();
j--;
};
return 0;
}
看看操作结果:
队员数据输入:
请输入第1位队员的信息:
请输入您的编号: 1
请输入您的姓名: a
请输入第2位队员的信息:
请输入您的编号: 2
请输入您的姓名: b
请输入第3位队员的信息:
请输入您的编号: 3
请输入您的姓名: c
请输入第4位队员的信息:
请输入您的编号: 4
请输入您的姓名: d
请输入第5位队员的信息:
请输入您的编号: 5
请输入您的姓名: e
队员数据输出:
第5位队员的信息:
编号: 5
姓名: e
第4位队员的信息:
编号: 4
姓名: d
第3位队员的信息:
编号: 3
姓名: c
第2位队员的信息:
编号: 2
姓名: b
第1位队员的信息:
编号: 1
姓名: a
完成了入栈,出栈操作!
相关链接:
C/C++ 学习手札(一)
C/C++ 学习手札(二)
C/C++ 学习手札(三)
分享到:
相关推荐
这份"Perl学习手札"是为那些想要深入理解Perl语言特性和应用的初学者或有一定经验的开发者准备的宝贵资源。 首先,Perl的核心特性在于其灵活性和表达力。Perl语法受到了C、sed、awk等多种语言的影响,这使得它在...
"Perl学习手札中文"是一份专为初学者设计的学习资料,旨在帮助读者快速掌握Perl语言的基础和高级特性。以下是对这些文件内容的概览: 1. **word.css**: 这个文件可能是样式表,用于定义文档中的排版和格式。在学习...
关于作者: 简信昌 “傲尔网”专案经理 博仲法律事务所资讯部门 台北Perl推广组 (Taipei.pm) 召集人 Newzilla召集人 目前专案: Open Source Foundry (OSSF) Newzilla 线上杂志 ...“Perl学习手札”
Perl学习手札.chmPerl学习手札.chmPerl学习手札.chm
hibernate学习手札.z03
hibernate学习手札.z01
在学习51单片机的过程中,通常需要掌握两种编程语言,即汇编语言和C语言。汇编语言能够直接与硬件交互,生成的代码效率高,但可读性和可移植性较差。而C语言在大多数情况下,生成的代码效率接近汇编,同时具有更好的...
通过深入学习“Perl学习手札”,你可以系统地掌握这些概念,并逐步成长为一个熟练的Perl程序员。记住,实践是检验知识的最好方式,所以不仅要理解理论,还要动手编写代码,解决实际问题。祝你在Perl的学习之旅中取得...
<br/>本资料完全来源于网上收集,对于作者并没有做过多的考证,考虑到作者本身,所以保持原作品不变只是略加整理,为用户提供一个方便的浏览方式。<br/>
在本篇《Spring注解学习手札(三)表单页面处理》中,我们将深入探讨Spring框架中关于处理Web表单的关键注解和技术。在实际的Web开发中,表单处理是用户交互的重要组成部分,Spring提供了强大的支持,使得开发者能够...
"高级Perl编程(黑豹书)"和"Perl_学习手札"这两本书籍是深入理解并掌握Perl编程的重要资源。 《高级Perl编程》(黑豹书)是Perl编程领域的经典之作,它不仅适合初学者作为进阶读物,也对有经验的Perl程序员提供了...
【Spring注解学习手札】 在现代Java Web开发中,Spring框架因其强大的功能和灵活性而备受推崇。Spring注解的引入极大地简化了配置文件,提高了开发效率。本篇将聚焦于Spring MVC中的注解,通过构建一个简单的Web...
8086汇编学习手札及各章节检测题详细答案。 配套书籍 王爽的汇编
### Perl学习要点详解 #### 一、Perl简介与历史背景 Perl是一种强大的脚本语言,由Larry Wall在1987年设计并持续更新维护。它结合了C语言的强大功能和脚本语言的便捷性,使得Perl既适用于快速编写简单的脚本程序,...
这篇“Spring注解学习手札(二)控制层梳理”主要聚焦于如何利用注解来构建和理解Spring MVC的控制层,即Controller。Spring MVC是Spring框架的一部分,专门用于处理Web应用程序的请求和响应。 一、@RestController...
### 非常著名的Perl学习手札(初学者有福了) #### 1. 关于Perl5 **1.1 Perl的历史** Perl是由Larry Wall在1987年开发的一种高级编程语言,最初的设计目的是为了简化文本处理任务,后来发展成为一种功能强大的...
在本篇《Spring注解学习手札(一)构建简单Web应用》中,我们将深入探讨如何使用Spring框架的注解来构建一个基本的Web应用程序。Spring框架是Java开发中的核心工具,尤其在企业级应用中广泛应用。它简化了依赖注入、...
### 盟威Access快速开发平台学习手札 #### 一、引言 盟威Access快速开发平台是一款基于Microsoft Access的应用程序开发工具,旨在帮助开发者快速构建应用程序。通过使用该平台,用户无需具备复杂的编程知识就能完成...