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

相关文章

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3