【C++】day3学习成果:类

1.自行封装一个栈的类,包含私有成员属性:栈的数组、记录栈顶的变量
成员函数完成:构造函数、析构函数、拷贝构造函数、入栈、出栈、清空栈、判空、判满、获取栈顶元素、求栈的大小
头文件stack.h:

#ifndef STACK_H
#define STACK_H#include <iostream>using namespace std;#define MAX 8class Stack
{
private:int *data;      //栈的数组,指向堆区空间,用于存储栈的容器int top;        //记录栈顶的变量
public://无参构造函数Stack();//有参构造函数Stack(int data);//析构函数~Stack();//拷贝构造函数Stack(const Stack &other);//入栈bool stack_push(int e);//出栈bool stack_pop();//清空栈void stack_free();//判空bool stack_empty();//判满bool stack_full();//获取栈顶元素int stack_top();//求栈的大小int stack_size();
};#endif // STACK_H

源文件stack.cpp:

#include"stack.h"
#include<iostream>无参构造函数
//Stack::Stack(){}
有参构造函数
//Stack::Stack(int data){}
析构函数
//Stack::~Stack(){}
拷贝构造函数
//Stack::Stack(const Stack &other){}
//无参构造函数
Stack::Stack():top(-1),data(new int[MAX]){cout<<"Stack::无参构造函数:初始化栈成功"<<endl;
}
有参构造函数
//Stack::Stack(int data){
//    cout<<"Stack::有参构造函数"<<endl;
//    top=data;
//}
//析构函数
Stack::~Stack(){cout<<"Stack::析构函数"<<endl;delete []data;data=nullptr;
}
//拷贝构造函数
Stack::Stack(const Stack &other):data(other.data),top(other.top){cout<<"Stack::拷贝构造函数"<<endl;
}//入栈
bool Stack::stack_push(int e)
{if(top<-1){cout<<"所给栈不合法"<<endl;return false;}else if(stack_full()){cout<<"入栈失败,栈满"<<endl;return false;}//先加后压top++;this->data[top]=e;cout<<data[top]<<"入栈成功"<<endl;return true;
}//出栈
bool Stack::stack_pop()
{if(top<-1){cout<<"所给栈不合法"<<endl;return false;}//出栈逻辑:先弹后减cout<<data[top]<<"出栈成功"<<endl;top--;return true;
}//清空栈
void Stack::stack_free()
{if(top<-1){cout<<"所给栈不合法"<<endl;return;}for(top;top>-1;top--){stack_pop();}top=-1;cout<<"清空成功"<<endl;
}//判空
bool Stack::stack_empty()
{if(top==-1){return true;}else{if(top<-1){cout<<"所给栈不合法"<<endl;}return false;}
}//判满
bool Stack::stack_full()
{if(top<-1){cout<<"所给栈不合法"<<endl;return false;}else if(top==MAX-1){return true;}else{return false;}}//获取栈顶元素
int Stack::stack_top()
{if(top<-1||stack_empty()){cout<<"获取失败"<<endl;return NULL;}return data[top];
}//求栈的大小
int Stack::stack_size()
{if(!stack_empty()){return top+1;}cout<<"所给链表不合法"<<endl;return -1;
}

主函数main.cpp:

#include "stack.h"int main()
{Stack s;//入栈for(int i=MAX;i>=0;i--){s.stack_push(i);}if(s.stack_full()){cout<<"栈满"<<endl;}//出栈for(int i=0;i<MAX;i++){s.stack_pop();}s.stack_push(1);s.stack_push(2);s.stack_push(3);s.stack_push(11);s.stack_push(12);s.stack_push(111);cout<<"栈顶元素为:"<<s.stack_top()<<endl;s.stack_pop();cout<<"栈顶元素为:"<<s.stack_top()<<endl;s.stack_free();if(s.stack_empty()){cout<<"栈空"<<endl;}s.stack_push(1);cout<<"栈顶元素为:"<<s.stack_top()<<endl;s.stack_push(2);s.stack_push(3);cout<<"栈顶元素为:"<<s.stack_top()<<endl;Stack s2;s2.stack_push(3);s2.stack_push(2);s2.stack_push(1);s=s2;cout<<"栈顶元素为:"<<s.stack_top()<<endl;cout<<"&s2="<<&s2<<",&s="<<&s<<endl;return 0;
}

运行结果:
运行结果1

2.自行封装一个循环顺序队列的类,包含私有成员属性:存放队列的数组、队头位置、队尾位置
成员函数完成:构造函数、析构函数、拷贝构造函数、入队、出队、清空队列、判空、判满、求队列大小

头文件linkqueue.h:

#ifndef LINKQUEUE_H
#define LINKQUEUE_H#include <iostream>using namespace std;#define MAX 8class ListQueue
{
private:int *data;      //存放队列的数组,初始化时向堆区申请数组空间int front;      //队头位置,记录对头所在的元素下标int tail;      //队尾位置,记录最后一个元素的下一个下标的位置
public://无参构造函数ListQueue();//有参构造函数ListQueue(int data);//析构函数~ListQueue();//拷贝构造函数ListQueue(const ListQueue &other);//入队bool ListQueue_push(int e);//出队bool ListQueue_pop();//清空队void ListQueue_free();//判空bool ListQueue_empty();//判满bool ListQueue_full();//求队列的大小int ListQueue_size();
};#endif // LINKQUEUE_H

源文件linkQueue.cpp:

#include "linkQueue.h"//无参构造函数
ListQueue::ListQueue():data(new int[MAX]),front(0),tail(0)
{cout<<"Stack::无参构造函数:初始化循环队列成功"<<endl;
}
//有参构造函数
//ListQueue::ListQueue(int data){}//析构函数
ListQueue::~ListQueue()
{cout<<"Stack::析构函数"<<endl;delete []data;data=nullptr;
}//拷贝构造函数
ListQueue::ListQueue(const ListQueue &other):data(other.data),front(other.front),tail(other.tail)
{cout<<"Stack::拷贝构造函数"<<endl;
}//入队
bool ListQueue::ListQueue_push(int e)
{if(ListQueue_full()){cout<<"入队失败\n"<<endl;return false;}//将数据放在队尾所在地方data[tail]=e;cout<<"data["<<tail<<"]="<<e<<" 入队成功"<<endl;//队尾后移tail=(tail+1)%MAX;return true;
}//出队
bool ListQueue::ListQueue_pop()
{if(ListQueue_empty()){cout<<"出队失败\n"<<endl;return false;}cout<<"data["<<front<<"]="<<data[front]<<" 出队成功"<<endl;//队头后移front=(front+1)%MAX;return true;
}
//清空队
void ListQueue::ListQueue_free()
{for(int i=front;i<tail;i++){data[i]=NULL;}front=tail=0;cout<<"清空队列成功"<<endl;
}//判空
bool ListQueue::ListQueue_empty()
{if(front==tail){return true;}else{return false;}
}//判满
bool ListQueue::ListQueue_full()
{if((tail+MAX)%MAX==front && !ListQueue_empty()){return true;}else{return false;}
}
//求队列的大小
int ListQueue::ListQueue_size()
{return (tail+MAX-front)%MAX;
}

主函数main.c:

#include "linkQueue.h"int main()
{ListQueue queue;queue.ListQueue_push(1);queue.ListQueue_push(2);queue.ListQueue_push(3);queue.ListQueue_push(8);queue.ListQueue_push(9);queue.ListQueue_push(10);queue.ListQueue_push(11);queue.ListQueue_push(12);queue.ListQueue_push(13);queue.ListQueue_pop();queue.ListQueue_push(1);queue.ListQueue_free();queue.ListQueue_push(10);queue.ListQueue_push(11);queue.ListQueue_push(12);cout<<"size of queue="<<queue.ListQueue_size()<<endl;cout<<"*************************"<<endl;ListQueue queue2;queue2.ListQueue_push(1);queue2=ListQueue(queue);cout<<"size of queue2="<<queue2.ListQueue_size()<<endl;return 0;
}

运行结果:
运行结果2

3.思维导图
C++day3

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/127393.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux常见指令

目录 前言 一、Linux下的基本指令 01. ls 指令 02. pwd 指令 03. cd 指令 04. touch 指令 05. mkdir 指令&#xff08;重要&#xff09; 06. rmdir 指令 && rm 指令&#xff08;重要&#xff09; 07. man 指令&#xff08;重要&#xff09; extra nano 08. cp 指…

并发聊天服务器编写

并发聊天服务器 package mainimport ("fmt""net""strings""time" )// 结构体 type Client struct {C chan string //用户发送数据的管道Name string //用户名Addr string //网络地址 }// 保存在线用户 cliAddr -->cli…

UNIX网络编程卷一 学习笔记 第三十一章 流

在大多数源自SVR 4的内核中&#xff0c;X/Open传输接口&#xff08;X/Open Transport Interface&#xff0c;XTI&#xff0c;是独立于套接字API的另一个网络编程API&#xff09;和网络协议通常就像终端IO系统那样也使用流系统&#xff08;STREAMS system&#xff09;实现。 我…

Selenium 隐藏浏览器指纹特征的几种方式

我们使用 Selenium 对网页进行爬虫时&#xff0c;如果不做任何处理直接进行爬取&#xff0c;会导致很多特征是暴露的 对一些做了反爬的网站&#xff0c;做了特征检测&#xff0c;用来阻止一些恶意爬虫 本篇文章将介绍几种常用的隐藏浏览器指纹特征的方式 1. 直接爬取 目标对…

基于微服务+Java+Spring Cloud +UniApp +MySql开发的智慧工地源码(物联网、人工智能、AI识别、危大工程)

智慧工地系统利用物联网、人工智能、云计算、大数据、移动互联网等新一代信息技术&#xff0c;通过工地中台、三维建模服务、视频AI分析服务等技术支撑&#xff0c;实现智慧工地高精度动态仿真&#xff0c;趋势分析、预测、模拟&#xff0c;建设智能化、标准化的智慧工地综合业…

vue3+ts项目打包后的本地访问

注意&#xff1a;打包之后不可直接点击html访问&#xff0c;需要给项目安装本地服务&#xff01; 1、安装servenpm i -g serve 2、打包项目npm run build 生成dist文件夹 3、本地访问serve dist 运行service dist之后的控制台 可复制下方的地址运行打包后的项目&#xff0c;运行…

强大的JTAG边界扫描(5):FPGA边界扫描应用

文章目录 1. 获取芯片的BSDL文件2. 硬件连接3. 边界扫描测试4. 总结 上一篇文章&#xff0c;介绍了基于STM32F103的JTAG边界扫描应用&#xff0c;演示了TopJTAG Probe软件的应用&#xff0c;以及边界扫描的基本功能。本文介绍基于Xilinx FPGA的边界扫描应用&#xff0c;两者几乎…

opencv识别一张图片的多个红框,并截取红框的内容

需求 需要获取图片的红框的内容&#xff0c;实体的图片我就不放了 获取红框 先截取获得图片的多个轮廓 import cv2 import numpy as np # 加载图像并转换为灰度图像 image cv2.imread(image6.jpg) gray cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) # 应用高斯模糊以减…

保姆级-微信小程序开发教程

一&#xff0c;注册微信小程序 如果你还没有微信公众平台的账号&#xff0c;请先进入微信公众平台首页&#xff0c;点击 “立即注册” 按钮进行注册。注册的账号类型可以是订阅号、服务号、小程序以及企业微信&#xff0c;我们选择 “小程序” 即可。 接着填写账号信息&#x…

文件操作(个人学习笔记黑马学习)

C中对文件操作需要包含头文件<fstream > 文件类型分为两种: 1.文本文件&#xff1a;文件以文本的ASCII码形式存储在计算机中 2.二进制文件&#xff1a;文件以文本的二进制形式存储在计算机中&#xff0c;用户一般不能直接读懂它们 操作文件的三大类: 1.ofstream: 写操作 …

生成多样、真实的评论(2019 IEEE International Conference on Big Data )

论文题目&#xff08;Title&#xff09;&#xff1a;Learning to Generate Diverse and Authentic Reviews via an Encoder-Decoder Model with Transformer and GRU 研究问题&#xff08;Question&#xff09;&#xff1a;评论生成&#xff0c;由上下文评论->生成评论 研…

Java类和对象(七千字详解!!!带你彻底理解类和对象)

目录 一、面向对象的初步认知 1、什么是面向对象 2、面向对象和面向过程 &#xff08;1&#xff09;传统洗衣服的过程 &#xff08;2&#xff09;现代洗衣服过程 ​编辑 二、类的定义和使用 1、类的定义格式 三、类的实例化 1、什么是实例化 2、类和对象说明 四、t…

计算机网络初识

目录 1、计算机网络背景 网络发展 认识 "协议" 2、网络协议初识 OSI七层模型 TCP/IP五层(或四层)模型 3、网络传输基本流程 网络传输流程图 数据包封装和分用 4、网络中的地址管理 认识IP地址 认识MAC地址 1、计算机网络背景 网络发展 在之前呢&…

redis如何保证接口的幂等性

背景 如何防止接口中同样的数据提交&#xff0c;以及如何保证消息不被重复消费&#xff0c;这些都是shigen在学习的过程中遇到的问题。今天&#xff0c;趁着在学习redis的间隙&#xff0c;我写了一篇文章进行简单的实现。 注意&#xff1a;仅使用于单机的场景&#xff0c;对于…

Android Studio实现一笔画完小游戏

文章目录 一、项目概述二、开发环境三、详细设计3.1、数据库设计3.2、普通模式3.3、随机模式3.4、关卡列表 四、运行演示五、项目总结六、源码获取 一、项目概述 Android一笔画完是一种益智游戏&#xff0c;玩家需要从起点开始通过一条连续的线&#xff0c;将图形中所有的方块…

一种基于注意机制的快速、鲁棒的混合气体识别和浓度检测算法,配备了具有双损失函数的递归神经网络

A fast and robust mixture gases identification and concentration detection algorithm based on attention mechanism equipped recurrent neural network with double loss function 摘要 提出一个由注意力机制组成的电子鼻系统。首先采用端到端的编码器译码器&#xff…

树莓派入门

目录 前言系统烧录使用官方烧录工具选择操作系统选择存储卡配置 Win32DiskImager 有屏幕树莓派开机树莓派关机无屏幕树莓派开机获取树莓派IP地址通过路由器获取共享网络方式获取给树莓派配置静态IP地址查找默认网关分盘给树莓派的IP地址修改树莓派DHCP配置文件 ssh登录 让树莓派…

C# PSO 粒子群优化算法 遗传算法 随机算法 求解复杂方程的最大、最小值

复杂方程可以自己定义&#xff0c;以下是看别人的题目&#xff0c;然后自己来做 以下是计算结果 private void GetMinResult(out double resultX1, out double min){double x1, result;Random random1 new Random(DateTime.Now.Millisecond* DateTime.Now.Second);min 99999…

数字城市:科技革命下的未来之城

随着科技的不断进步&#xff0c;数字城市已经成为了未来城市发展的关键趋势。数字城市是指利用先进的信息技术、互联网和大数据等工具&#xff0c;将城市各个方面进行数字化、智能化、互联化的发展模式。它不仅仅是一种技术&#xff0c;更是一种对城市管理、发展和居民生活方式…

局域网ntp服务器设置(windows时间同步服务器NetTime)(ubuntu systemd-timesyncd ntp客户端)123端口、ntp校时

文章目录 背景windows如何配置ntp服务器手动配置配置参数AnnounceFlags和Enabled含义 使用软件配置&#xff08;NetTime&#xff09;实操相关疑问&#xff1a;0.nettime.pool.ntp.org是什么&#xff1f; 注意事项请务必检查windows主机123端口是否已被占用&#xff0c;方法请参…