C/C++ 学习手札(三)

2024-01-15 19:08
文章标签 c++ 学习 手札

本文主要是介绍C/C++ 学习手札(三),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

接着说说友员[b]friend[/b]和操作符重载[b]operator[/b],为了把这两个搞清楚,费了大半天劲儿搞了一个堆栈,被一堆指针问题搞得头都大了! :( 不过,最终还是OK了! :D

这次做这么一件事,搞体育活动。每个团队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);
}

构建一个重载操作符,注意使用[b]&[/b]符号,引用方式,且操作符重载必须是友员方法!

/**
* 重载输入操作符
*/
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];

关于指针的使用,我还解释不清楚,久远的过去了能将就用了! :D
看看整体的程序吧!

#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



:D 完成了入栈,出栈操作! :D


相关链接:
[url=http://snowolf.iteye.com/blog/402483]C/C++ 学习手札(一)[/url]
[url=http://snowolf.iteye.com/blog/410102]C/C++ 学习手札(二)[/url]
[url=http://snowolf.iteye.com/blog/410984]C/C++ 学习手札(三)[/url]

这篇关于C/C++ 学习手札(三)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/609909

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]