当前位置: 首页 > news >正文

C++ --- Day02 封装

stack栈类

stack.h

#ifndef STACK_H
#define STACK_H
#include <iostream>
#include<string>
using namespace std;
//自行封装一个栈的类,包含私有成员属性:栈的数组、记录栈顶的变量
//成员函数完成:
//构造函数、析构函数、拷贝构造函数
//入栈、出栈、清空栈、判空、判满、获取栈顶元素、求栈的大小template <class T>
class Mystack
{
private:T *arr;int top;int size;
public://无参构造函数Mystack(){this->size = 100;this->arr = new T[size];this->top = -1;}//有参构造函数Mystack(int arrnum){this->size = arrnum;this->arr = new T[arrnum];this->top = -1;}//拷贝构造函数Mystack(const Mystack &stk){this->size = stk.size;cout<<this->size << " " << stk.size<<endl;this->arr = new T[size];for(int i = 0 ; i<stk.top ; i++){*(arr+i) = *(stk.arr+i);}this->top = stk.top;cout<<"1top:"<<this->top <<" " << stk.top<<endl;}//拷贝赋值函数Mystack& operator=(const Mystack &stk){this->size = stk.size;this->arr = new T[size];for(int i = 0 ; i<stk.top ; i++){*(arr+i) = *(stk.arr+i);}this->top = stk.top;return *this;}//析构函数~Mystack(){delete arr;}int getTop() const;//判空bool empty();//判满bool full();//入栈void push(T elem);//出栈void pop();//获取栈顶元素T& topelem();//求栈大小int stksize();
};
#endif // STACK_H

main.cpp

#include "stack.cpp"
//int类型
void test()
{cout<<"stk1:"<<endl;Mystack<int> stk(100);for(int i = 0 ; i<10;i++)stk.push(i+1);cout<<"stk的栈顶元素:"<<stk.topelem()<<endl;cout<<"stk的大小:"<<stk.stksize()<<endl;stk.pop();cout<<"stk的栈顶元素:"<<stk.topelem()<<endl;cout<<"stk的大小:"<<stk.stksize()<<endl;cout<<"stk2:"<<endl;Mystack<int> stk2(stk);cout<<"stk2的栈顶元素:"<<stk2.topelem()<<endl;cout<<"stk2的大小:"<<stk2.stksize()<<endl;stk2.pop();cout<<"stk2的栈顶元素:"<<stk2.topelem()<<endl;cout<<"stk2的大小:"<<stk2.stksize()<<endl;
}//string类型
void test2()
{Mystack<string> stk(10);stk.push("1");stk.push("2");stk.push("3");stk.push("4");stk.push("5");stk.push("6");cout<<stk.topelem()<<endl;cout<<stk.stksize()<<endl;stk.pop();cout<<stk.topelem()<<endl;cout<<stk.stksize()<<endl;}
int main()
{test();//test2();return 0;
}

queue.cpp

#include"stack.h"template <class T>
int Mystack<T>::getTop() const
{return top;
}template <class T>
bool Mystack<T>::empty()
{if(top == -1)return true;return false;
}template <class T>
bool Mystack<T>::full()
{if(top == size-1)return true;return false;
}
//入栈
template <class T>
void Mystack<T>::push(T elem)
{if(full())return;top = top + 1;this->arr[top] = elem;}
//出栈
template <class T>
void Mystack<T>::pop()
{if(empty())return;this->top--;
}//获取栈顶元素
template <class T>
T& Mystack<T>::topelem()
{return *(arr+top);
}//求栈大小
template <class T>
int Mystack<T>::stksize()
{return this->top+1;
}

queue队列

queue.h

#ifndef QUEUE_H
#define QUEUE_H
#include <iostream>
//自行封装一个循环顺序队列的类,包含私有成员属性:存放队列的数组、队头位置、队尾位置
//成员函数完成:构造函数、析构函数、拷贝构造函数、入队、出队、清空队列、判空、判满、求队列大小
using namespace std;
template <class T>
class Queue
{
private:T *arr;int head;int tail;int size;
public://无参构造Queue();//有参构造Queue(int elemnum);//拷贝构造Queue(const Queue &q);//拷贝赋值函数void operator=(Queue &q);//析构函数~Queue();//判空bool empty();//判满bool full();//入队void push(T elem);//出队void pop();//清空队列void clear();//求队列大小int queuesize();//返回最后一个元素T* back();//返回第一个元素T* front();
};
#endif // QUEUE_H

main.cpp

#include"queue.cpp"void test()
{Queue<int> q1(20);for(int i = 0;i < 10;i++){q1.push(i+1);}cout<<"第一个元素: "<<*q1.front()<<endl;cout<<"最后一个元素: "<<*q1.back()<<endl;q1.pop();cout<<"第一个元素: "<<*q1.front()<<endl;cout<<"最后一个元素: "<<*q1.back()<<endl;Queue<int> q2(q1);cout<<"q2的第一个元素: "<<*q2.front()<<endl;cout<<"q2的最后一个元素: "<<*q2.back()<<endl;Queue<int> q3;q3 = q1;cout<<"q3的第一个元素: "<<*q3.front()<<endl;cout<<"q3的最后一个元素: "<<*q3.back()<<endl;
}
int main()
{test();return 0;
}

queue.cpp

#include"queue.h"
//无参构造
template <class T>
Queue<T>::Queue():arr(new T[100]),head(0),tail(0),size(100)
{
}
//有参构造
template <class T>
Queue<T>::Queue(int elemnum):arr(new T[elemnum]),head(0),tail(0),size(elemnum)
{
}
//拷贝构造
template <class T>
Queue<T>::Queue(const Queue &q):arr(new T[q.size]),head(q.head),tail(q.tail),size(q.size)
{int i = q.head;while(i != q.tail){*(this->arr+i) = *(q.arr+i);i = (i+1+q.size)%q.size;}
}
//析构函数
template <class T>
Queue<T>::~Queue()
{delete arr;
}
//拷贝赋值函数
template <class T>
void Queue<T>::operator=(Queue &q)
{arr = new T[q.size];head = q.head;tail = q.tail;size = q.size;int i = q.head;while(i != q.tail){*(this->arr+i) = *(q.arr+i);i = (i+1+q.size)%q.size;}return *this;
}
//判空
template <class T>
bool Queue<T>::empty()
{return head == tail;
}
//判满
template <class T>
bool Queue<T>::full()
{return  (tail+1)%size == head;
}//入队
template <class T>
void Queue<T>::push(T elem)
{if(full())cout<<"队满"<<endl;else{arr[tail] = elem;tail=(tail+1)%size;}
}
//出队
template <class T>
void Queue<T>::pop()
{if(empty()){}elsehead=(head+1)%size;
}
//清空队列
template <class T>
void Queue<T>::clear()
{head = 0;tail = head;
}
//求队列大小
template <class T>
int Queue<T>::queuesize()
{return (tail+size-head)%size;
}
//返回最后一个元素
template <class T>
T* Queue<T>::back()
{if(empty()){T *elem = nullptr;cout<<"空队列"<<endl;return elem;}elsereturn arr+(tail+size-1)%size;
}
//返回第一个元素
template <class T>
T* Queue<T>::front()
{if(empty()){T *elem = nullptr;cout<<"空队列"<<endl;return elem;}elsereturn arr+head;
}

相关文章:

C++ --- Day02 封装

stack栈类 stack.h #ifndef STACK_H #define STACK_H #include <iostream> #include<string> using namespace std; //自行封装一个栈的类&#xff0c;包含私有成员属性:栈的数组、记录栈顶的变量 //成员函数完成: //构造函数、析构函数、拷贝构造函数 //入栈、出…...

墨西哥专线清关有什么要求?

墨西哥专线的清关要求是根据当地法规和国际贸易协定而定的。以下是一些墨西哥专线清关的常见要求&#xff1a; 一、 清关文件 进口货物需要提供一系列文件&#xff0c;包括商业发票、装箱单、进口许可证、运输文件、保险文件等。这些文件需要准确、完整地填写&#xff0c;并且…...

SpringMVC中的JSR303与拦截器的使用

一&#xff0c;JSR303的概念 JSR303是Java中的一个标准&#xff0c;用于验证和校验JavaBean对象的属性的合法性。它提供了一组用于定义验证规则的注解&#xff0c;如NotNull、Min、Max等。在Spring MVC中&#xff0c;可以使用JSR303注解对请求参数进行校验。 1.2 为什么要使用J…...

神经网络 01(介绍)

一、神经网络 人工神经网络 (Artificial Neural Network&#xff0c;简写为ANN)也简称为神经网络 (NN)&#xff0c;是一种模仿生物神经网络结构和功能的 计算模型。人脑可以看做是一个生物神经网络&#xff0c;由众多的神经元连接而成。各个神经元传递复杂的电信号&#xff0c…...

【element-ui】el-date-picker 之picker-options时间选择区间禁用效果的实现

element-ui 时间选择器的时间区间禁用dom层引入:picker-option <el-date-pickerv-model"searchFormObj.workTime"clearablevalue-formate"yyyy-MM-dd":picker-options"pickerOptions"placeholder"请选择时间" ></el-date-pi…...

Exchange Serve各版本说明及下载

Exchange Server各版本说明及官方下载 简介Exchange Server2019Exchange Server2016Exchange Server2013 本文为Exchange Server2013、Exchange Server2016及Exchange Server2019官方下载汇总&#xff0c;记录各版本号及发布日期的Exchange Server软件包 未经本人允许请勿转载&…...

软件测试 | 当面试时被问到“搭建过测试环境吗”, 身为小白要怎么回答?

首先&#xff0c;回答这个问题之前&#xff0c;你需要明确你所面试的职位需要什么样的测试环境。一些公司可能需要测试基础软件&#xff0c;而另一些公司则可能需要测试复杂的软件系统。因此&#xff0c;在回答这个问题之前&#xff0c;你需要了解面试职位所需要的测试环境是什…...

15.3K Star,超好用的开源协作式数字白板:tldraw

大家好&#xff0c;我是TJ 今天给大家推荐一个开源协作式数字白板&#xff1a;tldraw。 tldraw的编辑器、用户界面和其他底层库都是开源的&#xff0c;你可以在它的开源仓库中找到它们。它们也在NPM上分发&#xff0c;提供开发者使用。您可以使用tlDraw为您的产品创建一个临时…...

MGR新节点RECOVERING状态的分析与解决:caching_sha2_password验证插件的影响

起因 在GreatSQL社区上有一位用户提出了“手工构建MGR碰到的次节点一直处于recovering状态”&#xff0c;经过排查后&#xff0c;发现了是因为新密码验证插件caching_sha2_password导致的从节点一直无法连接主节点&#xff0c;帖子地址&#xff1a;(https://greatsql.cn/threa…...

git merging两边都被删除的文件

1. 场景&#xff1a; merge 另一个分支到当前分支&#xff0c;解决完冲突列表中的冲突后&#xff0c;发现项目任然在 merging 中&#xff0c;无法进行git下一步操作。 2. 原因&#xff1a; 通过 git status 发现一个文件&#xff0c;显示表面&#xff0c;该文件在当前分支和…...

项目--苍穹外卖

1.| constant | 存放相关常量类 | | context | 存放上下文类 | | enumeration | 项目的枚举类存储 | | exception | 存放自定义异常类 | | json | 处理json转换的类 | | properties | 存放SpringBoot相关的配置属性类 | | result | 返回结果类的封装 | | utils | 常用工具类 | …...

从零开发短视频电商 使用Spring WebClient发起远程Http调用

文章目录 依赖使用创建WebClient实例创建带有超时的WebClient实例示例 请求准备获取响应 高级过滤器自定义过滤器 自定义线程池自定义WebClient连接池开启日志错误处理最佳实践 示例异步请求同步请求上传文件重试过滤错误错误处理 参考 Spring WebClient 是 Spring WebFlux 项目…...

Python实现成语接龙

如图&#xff1a; 详细代码实现&#xff1a; # coding:utf-8 import string import pypinyin import sys import randomprint("初始化中&#xff0c;请稍等……")def main():f2 open(./idiom.txt, r, encodingutf-8)f f2.read() # 一次性读取完成new3_list f.sp…...

继续上一个爬虫,所以说selenium加browsermobproxy

继续&#xff0c;书接上回&#xff0c;这次我通过jsrpc&#xff0c;也学会了不少逆向的知识&#xff0c;感觉对于一般的网站应该都能应付了。当然我说的是简单的网站&#xff0c;遇到那些混淆的&#xff0c;还有那种猿人学里面的题目&#xff0c;还是免谈了。那种需要的水平太高…...

Sentinel服务熔断和流控

Sentinel服务熔断和流控 简介 Sentinel ​ 随着微服务的流行&#xff0c;服务和服务之间的稳定性变得越来越重要。Sentinel 是面向分布式服务架构的流量控制组件&#xff0c;主要以流量为切入点&#xff0c;从限流、流量整形、熔断降级、系统负载保护、热点防护等多个维度来…...

01_TMS320F28004x系列MCU介绍和资料搜集

1. TI C2000 实时微控制器 TI公司在处理器方面的产品线有&#xff1a;基于ARM内核的微控制器/微处理器、MSP430微控制器、C2000系列实时微控制器、还有数字信号处理器&#xff08;DSP&#xff09;。 其中&#xff0c;C2000是TI公司专门针对实时控制推出的32位微控制器。TI公司…...

JavaScript中获取对象属性的不同方法

JavaScript中获取对象属性的不同方法 文章目录 JavaScript中获取对象属性的不同方法一、点记法二、方括号记法三、Object.keys()方法四、Object.values()方法五、Object.entries()方法六、Object.getOwnPropertyNames()方法七、Object.getOwnPropertyDescriptors()方法 JavaScr…...

【STM32教程】第四章 STM32的外部中断EXTI

案例代码及相关资料下载链接&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1hsIibEmsB91xFclJd-YTYA?pwdjauj 提取码&#xff1a;jauj 1 中断系统 1.1 中断的概念 中断系统的定义&#xff1a;中断是指在主程序运行过程中&#xff0c;出现了特定的中断触发条件…...

力扣第40天----第121题、第122题

# 力扣第40天----第121题、第122题 文章目录 一、第121题--买卖股票的最佳时机二、第122题--买卖股票的最佳时机II 一、第121题–买卖股票的最佳时机 ​ 分2种情况考虑&#xff0c;根据持有股票、不持有股票这2种情况&#xff0c;完成递推公式。另外&#xff0c;这里要求只买卖…...

Flask 使用 JWT(二)

在 Python 使用 JWT 主要的方案是 PyJWT 工具。 安装与基本使用 可以使用 pip 安装 PyJWT: $ pip install pyjwt编码与解码 编码函数 def encode( self, payload: Dict[str, Any], # payload 参数 key: str, …...

从0到1理解ChatGPT原理

目录 写在前面 1.Tansformer架构模型 2.ChatGPT原理 3.提示学习与大模型能力的涌现 3.1提示学习 3.2上下文学习 3.3思维链 4.行业参考建议 4.1拥抱变化 4.2定位清晰 4.3合规可控 4.4经验沉淀 机械工业出版社京东自购链接 写在前面 2022年11月30日&#xff0c;ChatG…...

如何解决 “Component cannot be used as a JSX component“

原因是react版本与types/react版本不一致导致的, 在tsconfig.json中加入以下代码,将依赖指向项目里的node_modules "paths": {"react": [ "./node_modules/types/react" ]}改完后代码大概是长这样的 {"compilerOptions": {..."…...

小程序自定义tabbar

前言 使用小程序默认的tabbar可以满足常规开发&#xff0c;但是满足不了个性化需求&#xff0c;如果想个性化开发就需要用到自定义tabbar,以下图为例子 一、在app.json配置 先按照以往默认的形式配置&#xff0c;如果中间的样式特殊则不需要配置 "tabBar": {&qu…...

分布式系统第五讲:分布式事务及实现方案

分布式系统第五讲&#xff1a;分布式事务及实现方案 事务是一个程序执行单元&#xff0c;里面的所有操作要么全部执行成功&#xff0c;要么全部执行失败。而分布式事务是指事务的参与者、支持事务的服务器、资源服务器以及事务管理器分别位于不同的分布式系统的不同节点之上。本…...

算法通关村17关 | 透析跳跃游戏

1. 跳跃游戏 题目 LeetCode55 给定一个非负整数数组&#xff0c;最初位于数组的第一个位置&#xff0c;数组中的每个元素代表你再该位置可以跳跃的最大长度&#xff0c;判断你是否能够达到最后一个位置。 思路 如果当前位置元素如果是3&#xff0c;我们无需考虑是跳几步&#…...

ARM接口编程—RTC(exynos 4412平台)

RTC简介 RTC(Real Time Clock)即实时时钟&#xff0c;它是一个可以为系统提供精确的时间基准的元器件&#xff0c;RTC一般采用精度较高的晶振作为时钟源&#xff0c;有些RTC为了在主电源掉电时还可以工作&#xff0c;需要外加电池供电。 RTC内部原理 RTC寄存器 RTC控制寄存器 …...

数据分享|WEKA信贷违约预测报告:用决策树、随机森林、支持向量机SVM、朴素贝叶斯、逻辑回归...

完整报告链接&#xff1a;http://tecdat.cn/?p28579 作者&#xff1a;Nuo Liu 数据变得越来越重要&#xff0c;其核心应用“预测”也成为互联网行业以及产业变革的重要力量。近年来网络 P2P借贷发展形势迅猛&#xff0c;一方面普通用户可以更加灵活、便快捷地获得中小额度的贷…...

逆市而行:如何在市场恐慌时保持冷静并抓住机会?

市场中的恐慌和波动是投资者所不可避免的。当市场出现恐慌情绪时&#xff0c;很多投资者会盲目跟从大众&#xff0c;导致决策出现错误。然而&#xff0c;聪明的投资者懂得在恐慌中保持冷静&#xff0c;并将其视为抓住机会的时机。本文将分享一些在市场恐慌时保持冷静并抓住机会…...

SpringBoot项目在Linux上启动、停止脚本

文章目录 SpringBoot项目在Linux上启动、停止脚本1. 在项目jar包同一目录&#xff0c;创建脚本xxx.sh【注: 和项目Jar同一目录】2. xxx.sh脚本内容&#xff0c;实际项目使用&#xff0c;只需修改jar包的名称&#xff1a;xxxxxx.jar3. 给xxx.sh赋予执行权限4. xxx.sh脚本的使用 …...

基于32位单片机的感应灯解决方案

感应灯是一种常见照明灯&#xff0c;提起感应灯&#xff0c;相信大家并不陌生&#xff0c; 它在一些公共场所、卫生间或者走廊等场所&#xff0c;使用的较为广泛&#xff0c;同时它使用起来也较为方便省电。“人来灯亮&#xff0c;人走灯灭”的特性&#xff0c;使他们在部分场景…...

产品类型 速成网站/网站竞价推广托管公司

作者&#xff1a;Statmoon    出处&#xff1a;http://leolis.cnblogs.com/在编程过程中&#xff0c;数据转换是经常要用到的&#xff0c;C#中数据转换的方法很多&#xff0c;拿将目标对象转换为整型&#xff08;int&#xff09;来讲&#xff0c;有四种方法&#xff1a;分别…...

业网站制作/企业邮箱网页版

2.1数据运算高级语言中&#xff0c;运算通过表达式来表示。表达式又是通过运算符和运算分量组成&#xff0c;运算分量是指常量、变量、方法调用。JAVA的基本运算有下列几种:赋值运算算术运算、自增运算自减运算关系运算逻辑运算条件运算、字符串连接运算。2.1.1 赋值运算赋值运…...

攸县网站定制/护肤品软文推广

Chargpt是通过模仿人类的思考方式来理解复杂逻辑的。它会先读取输入文本&#xff0c;然后使用自然语言处理技术来理解文本中的词语和句子的含义。然后它会使用逻辑推理能力来思考文本中的逻辑关系&#xff0c;并利用这些信息来回答问题或完成其他任务。 Chargpt在理解复杂逻辑时…...

服装类电子商务网站建设报告/如何建网址

前言 Zuul 是 Netflix 开源的一个 API Gateway 服务器, 本质上是一个基于 Servlet 的 Web 应用。在微服务框架 Spring Cloud 中&#xff0c;Zuul 被作为 服务的网关&#xff0c;负责对 请求 进行一些 预处理&#xff0c;比如&#xff1a;安全验证、动态路由、负载分配 等等。 …...

网件路由器无线桥接/seo免费视频教程

在上篇文章里说完了日志实例Logger和日志管理Manager&#xff0c;现在该提到Handler了。Handler是日志信息的消费者&#xff0c;单个Logger实例注册多个Handler&#xff0c;每生成一个LogRecord&#xff0c;就会被合法的Handler消费&#xff0c;在不同地方打印出日志信息。 要…...

郑州微信网站建设/seo静态页源码

#include <windows.h> #include <stdio.h> #include <string.h> HANDLE hOut; HANDLE hIn; void ClearScreen(void); void DispMousePos(COORD pos); // 在第24行显示鼠标位置 int main() {hOut GetStdHandle(STD_OUTPUT_HANDLE); // 获取标准输出设备句柄h…...