2023年9月8日

1> 自行封装一个栈的类,包含私有成员属性:栈的数组、记录栈顶的变量

成员函数完成:构造函数、析构函数、拷贝构造函数、入栈、出栈、清空栈、判空、判满、获取栈顶元素、求栈的大小

#include <iostream>using namespace std;class Stack
{
private:int data[8];int top=-1;public://构造函数Stack(){}//构析函数~Stack(){}//拷贝构造函数Stack(const Stack &other){}//判空bool stack_empty(Stack *p){if(p->top==-1){return 1;}return 0;}//判满bool stack_full(Stack *p){if(p->top==7){return 1;}return 0;}//入栈void stack_push(Stack *p,int e){if(NULL==p||stack_full(p)){return;}p->top++;p->data[p->top]=e;cout<<e<<endl;cout<<"入栈成功"<<endl;return ;}//出栈void stack_pop(Stack *p){if(NULL==p||stack_empty(p)){return ;}int e=p->data[p->top];cout<<e<<"出栈成功"<<endl;p->top--;return;}//销毁栈void stack_free(Stack *p){if(NULL==p){return ;}delete p;p=nullptr;cout<<"销毁成功"<<endl;return ;}//获取栈顶元素void stack_gettop(Stack *p){if(NULL==p){return ;}int e = p->data[p->top];cout<<"栈顶元素为"<<e<<endl;return ;}//求栈的大小void stack_size(Stack *p){if(NULL==p){return ;}cout<<"栈的大小为"<<p->top+1<<endl;}void stack_show(Stack *p){for(int i=0;i<=p->top;i++){cout<<" "<<p->data[i];}cout<<endl;return ;}
};int main()
{//初始化Stack zhan;//定义一个Stack *p=new Stack(zhan);//入栈zhan.stack_push(p,812);zhan.stack_push(p,627);zhan.stack_push(p,908);zhan.stack_push(p,929);zhan.stack_push(p,199);zhan.stack_show(p);cout<<"*******************************"<<endl;//出栈zhan.stack_pop(p);zhan.stack_pop(p);zhan.stack_pop(p);zhan.stack_show(p);//获取栈顶元素zhan.stack_gettop(p);//求栈大小zhan.stack_size(p);//销毁栈zhan.stack_free(p);return 0;
}

2> 自行封装一个循环顺序队列的类,包含私有成员属性:存放队列的数组、队头位置、队尾位置

成员函数完成:构造函数、析构函数、拷贝构造函数、入队、出队、清空队列、判空、判满、求队列大小

#include <iostream>using namespace std;class Queue
{
private:int data[8];int front=0;int tail=0;public://构造函数Queue(){}//构析函数~Queue(){}//拷贝构造函数Queue(const Queue &other){}//判空int queue_empty(Queue *p){if(NULL==p){cout<<"队列不合法"<<endl;return -1;}return 0;}//判满int queue_full(Queue *p){if(NULL==p){cout<<"所给队列不和发"<<endl;return -1;}return 0;}//入队void queue_push(Queue *p,int e){if(NULL==p||queue_full(p)){cout<<"入队失败"<<endl;return ;}p->data[p->tail]=e;p->tail=(p->tail+1)%8;cout<<"入队成功"<<endl;return ;}//出队void queue_pop(Queue *p){if(NULL==p||queue_empty(p)){cout<<"出队失败"<<endl;return ;}cout<<p->data[p->front]<<"出队成功"<<endl;p->front=(p->front+1)%8;return ;}//求队列长度void queue_size(Queue *p){if(NULL==p){cout<<"所给队列不合法"<<endl;return ;}cout<<"队列长度为"<<(p->tail+8-p->front)%8<<endl;return ;}//销毁队列void queue_free(Queue *p){if(NULL!=p){free(p);p=NULL;cout<<"释放成功"<<endl;return ;}cout<<"所给队列不合法"<<endl;return ;}//遍历void queue_show(Queue *p){for(int i=p->front;i!=p->tail;i=(i+1)%8){cout<<p->data[i]<<" ";}cout<<endl;}
};
int main()
{//定义一个队列Queue dl;//创建指针 申请空间Queue *p=new Queue(dl);//入队dl.queue_push(p,8);dl.queue_push(p,60);dl.queue_push(p,19);dl.queue_push(p,627);dl.queue_push(p,78);dl.queue_push(p,1);dl.queue_push(p,2);dl.queue_show(p);cout<<"**********************"<<endl;//出队dl.queue_pop(p);dl.queue_pop(p);dl.queue_pop(p);dl.queue_show(p);cout<<"**********************"<<endl;//求队列长度dl.queue_size(p);//销毁队列dl.queue_free(p);return 0;
}

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

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

相关文章

selenium的Chrome116版驱动下载

这里写自定义目录标题 下载地址https://googlechromelabs.github.io/chrome-for-testing/#stable 选择chromedriver 对应的平台和版本 国内下载地址 https://download.csdn.net/download/dongtest/88314387

WorkPlus AI助理,基于ChatGPT的企业级知识问答机器人

随着人工智能技术的发展&#xff0c;WorkPlus AI助理以ChatGPT对话能力为基础&#xff0c;将企业数据与人工智能相结合&#xff0c;推出了面向企业的知识问答机器人。这一创新性的解决方案帮助企业高效管理和利用自身的知识资产&#xff0c;助力企业级人工智能的构建。与传统的…

【MySQL】数据库的约束

MySQL 数据库的约束 文章目录 MySQL 数据库的约束01 数据库的约束1.1 约束类型1.1.1 NOT NULL1.1.2 UNIQUE1.1.3 DEFAULT1.1.4 PRIMARY KEY1.1.5 FOREIGN KEY1.1.6 CHECK 继上文 MySQL基础&#xff08;一&#xff09;&#xff0c; MySQL基础&#xff08;二&#xff09;&#…

详解初阶数据结构之顺序表(SeqList)——单文件文件实现SeqList的增删查改

目录 一、线性表 二、顺序表 2.1概念及结构 2.2接口实现 2.3动态顺序表的创建 2.3动态顺序表的初始化 2.3.1传值初始化 2.3.2传址初始化 2.4动态顺序表的清空 2.5动态顺序表的扩容 2.6动态顺序表内容的打印 三、动态顺序表的使用 3.1尾插尾删 3.1.1尾插 3.1.2尾删…

基于Bert+Attention+LSTM智能校园知识图谱问答推荐系统——NLP自然语言处理算法应用(含Python全部工程源码及训练模型)+数据集

目录 前言总体设计系统整体结构图系统流程图 运行环境Python 环境服务器环境 模块实现1. 构造数据集2. 识别网络3. 命名实体纠错4. 检索问题类别5. 查询结果 系统测试1. 命名实体识别网络测试2. 知识图谱问答系统整体测试 工程源代码下载其它资料下载 前言 这个项目充分利用了…

linux编辑器-vim

1.vim是什么 vim 是从 vi 发展出来的一个文本编辑器。代码补全、编译及错误跳转等方便编程的功能特别丰富&#xff0c;在程序员中被广泛使用。简单的来说&#xff0c; vi 是老式的字处理器&#xff0c;不过功能已经很齐全了&#xff0c;但是还是有可以进步的地方。 vim 则可以…

前端uniapp块样式写法

<template><view class"block"><view class"block_box"><view class"block_box_content"><view class"block_box_left">左边</view><view class"block_box_right">右边</view…

线性代数的学习和整理22:矩阵的点乘(草稿)

4 矩阵乘法 A,B两个同阶同秩N阵&#xff0c;看上去结构一样&#xff0c;但两厢相乘&#xff0c;在做在右&#xff0c;地位差别巨大。 在左&#xff0c;你就是基&#xff0c;是空间的根本&#xff0c;是坐标系&#xff0c;是往哪去、能到哪的定海神针&#xff0c;是如来佛手&a…

华为云云耀云服务器L实例评测|华为云云耀云服务器L实例评测使用

作者简介&#xff1a; 辭七七&#xff0c;目前大一&#xff0c;正在学习C/C&#xff0c;Java&#xff0c;Python等 作者主页&#xff1a; 七七的个人主页 文章收录专栏&#xff1a; 七七的闲谈 欢迎大家点赞 &#x1f44d; 收藏 ⭐ 加关注哦&#xff01;&#x1f496;&#x1f…

[docker]笔记-portainer的安装

1、portainer是一款可视化的容器管理软件&#xff0c;利用portainer可以轻松方便的管理和创建容器。portainer本身是一个容器&#xff0c;完全免费并且具有汉化版。本文介绍portainer的安装和使用。 2、安装好容器并配置好容器环境&#xff0c;可参照https://blog.csdn.net/bl…

智安网络|面临日益增长的安全威胁:云安全和零信任架构的重要性

随着云计算技术的快速发展和广泛应用&#xff0c;云安全和零信任架构变得愈发重要。在数字化时代&#xff0c;云计算技术得到了广泛的应用和推广。企业和组织借助云服务提供商的强大能力&#xff0c;实现了高效、灵活和可扩展的IT基础设施。然而&#xff0c;随着云环境的快速发…

解决VSCode调试或者发布运行时闪退问题

解决方案&#xff1a;此方案不一定适合所有类型的闪退&#xff0c;但可以尝试一下。 步骤1&#xff1a;依次选择&#xff1a;文件→首选项→设置 步骤2&#xff1a;搜索 terminal.integrated.Default →找到Terminal > Integrated Default Profile: Windows选项→下拉框的…

Reinforcement Learning for Solving the Vehicle Routing Problem

Reinforcement Learning for Solving the Vehicle Routing Problem 一、背景二、模型三、公式 一、背景 本篇论文讨论一种有容量限制的版本CVRP&#xff0c;一辆有有限容量的车辆负责向地理分布的、需求有限的客户交付物品&#xff1b;当车辆的负载耗尽&#xff0c;它返回仓库…

200行代码实现canvas九宫格密码锁

现在很多app&#xff0c;在一些隐私页面&#xff0c;往往都会加入二次验证&#xff0c;例如银行app、支付宝理财和我的页面&#xff0c;一般会有「九宫格密码」和指纹密码。 今天我们用canvas来写一个九宫格手势密码锁&#xff0c;大概就是下面这样。 思路 准备一个正方形画布…

手写Spring:第7章-实现应用上下文

文章目录 一、目标&#xff1a;实现应用上下文二、设计&#xff1a;实现应用上下文三、实现&#xff1a;实现应用上下文3.1 工程结构3.2 Spring应用上下文和Bean对象扩展类图3.3 对象工厂和对象扩展接口3.3.1 对象工厂扩展接口3.3.2 对象扩展接口 3.4 定义应用上下文3.4.1 定义…

MySQL卸载干净再重新安装【Windows】

家人们&#xff0c;谁懂啊&#xff1f; 上学期学的数据库&#xff0c;由于上学期不知道为什么抽风&#xff0c;过得十分的迷&#xff0c;上课跟老师步骤安装好了Mysql&#xff0c;但后面在使用的过程中出现了问题&#xff0c;而且还出现了忘记密码这么蠢的操作&#xff0c;后半…

Splunk Enterprise for Mac:卓越的数据分析与管理工具

在当今的数字化时代&#xff0c;数据已经成为企业成功的核心驱动力。然而&#xff0c;如何有效地管理和分析这些数据&#xff0c;却常常让企业感到困惑。Splunk Enterprise for Mac 是一款领先的数据分析和管理工具&#xff0c;可以帮助你解决这一难题。 Splunk Enterprise fo…

在linux上挂载windows共享目录

挂载要求 非root用户&#xff08;普通用户&#xff09;能够读写windows共享目录&#xff0c;比如查看文件、创建文件、修改文件、删除文件 # 让普通用户也可以正常读写 uidvalue and gidvalue Set the owner and group of the root of the file system (default: uidgid0, bu…

阿里云ubuntu服务器搭建ftp服务器

阿里云ubuntu服务器搭建ftp服务器 服务器环境安装步骤一.创建用户二.安装 vsftp三 配置vsftp四.配置阿里云安全组 服务器环境 阿里云上的云服务器&#xff0c;操作系统为 ubuntu20.04。 安装步骤 一.创建用户 为什么需要创建用户&#xff1f; 这里的用户&#xff0c;指的是…

NFT 合约部署教程

本篇文章主要介绍如何将您的 NFT(ERC-721 Token) 通过智能合约部署到去中心化网络中 Init Project //创建一款ocean的NFT mkdir nft-ocean//进入目录 cd nft-ocean//初始化项目&#xff0c;根据提示填写即可&#xff0c;packname和description填写即可 npm init//添加hardhat…