23062C++QTday5

news2025/1/20 22:41:30

将之前定义的栈类和队列类都实现成模板类

栈:

#include <iostream>
#define MAX 128

using namespace std;


template<typename T,typename C>
class Stack
{
private:
    T top;              //栈顶元素的下标
    C *data;           //指向堆区空间


public:
    Stack():top(-1),data(new C[MAX]) {}           //无参构造

    //析构函数
    ~Stack()
    {
        delete[] data;
        cout<<"析构函数"<<endl;
    }
    //拷贝构造函数
    Stack(const Stack &other):top(other.top),data(new T(*other.data))
    {
        for(int i=0;i<=top;i++)
        {
            data[i]=other.data[i];
        }
        cout<<"拷贝构造函数"<<endl;
    }
    //入栈
    int Stack_push(C e)
    {
        top++;
        data[top]=e;
        cout<<"入栈成功"<<endl;
        return 0;
    }
    //出栈
    int Stack_pop()
    {
        top--;
        cout<<"出栈成功"<<endl;
        return 0;
    }
    //清空栈
    void Stack_clear()
    {
        top=-1;
        return;
    }
    //判空
    bool Stack_empty()
    {
        return top==-1;
    }
    //判满
    bool Stack_full()
    {
        return top==MAX-1;
    }
    //获取栈顶元素
    C & Stack_top()
    {
        return data[top];
    }
    //求栈的大小
    int Stack_size()
    {
        return top+1;
    }
};

int main()
{
    Stack<int,int> n1;
    n1.Stack_push(1);
    n1.Stack_push(2);
    cout<<"栈的大小为"<<n1.Stack_size()<<endl;
    cout<<"栈顶元素为"<<n1.Stack_top()<<endl;
    Stack<int,string> n2;
    n2.Stack_push("hello");
    n2.Stack_push(" world");
    cout<<"栈的大小为"<<n2.Stack_size()<<endl;
    cout<<"栈顶元素为"<<n2.Stack_top()<<endl;

    return 0;
}

运行结果:

队列:

代码:

#include <iostream>
#define MAX 128

using namespace std;


template<typename C>
class queue
{
private:
    int front;
    int tail;
    C data[MAX];


public:

    //构造函数
    queue():front(0),tail(0)
    {
        cout<<"构造函数"<<endl;
    }
    //析构函数
    ~queue()
    {
        cout<<"析构函数"<<endl;
    }
    //拷贝构造函数
    queue(const queue &other ):data(new C(*other.data))
    {
        int index=front;
        while(index!=tail)
        {
            data[index]=other.data[index];
            index=(index+1)%128;
        }
        cout<<"拷贝构造函数"<<endl;
    }
    //入队
    int queue_push(C e)
    {
        if(queue_full())
        {
            return -1;
        }
        data[tail]=e;
        tail=(tail+1)%128;
        return 0;

    }
    //出队
    int queue_pop()
    {
        if(queue_empty())
        {
            return -1;
        }
        front=(front+1)%128;
        return 0;
    }
    //清空队列
    void queue_delete()
    {
        tail=front=0;
    }
    //判空
    bool queue_empty()
    {
        return front==tail;
    }
    //判满
    bool queue_full()
    {
        return (tail+1)%128==front;
    }
    //求队列的大小
    int queue_size()
    {
        return (tail-front+128)%128;
    }

    //遍历
    void queue_show()
    {
        for(int i=front;i!=tail;i=(i+1)%128)
        {
            cout<<data[i]<<" ";
        }
        putchar(10);
    }
};
int main()
{
    queue<int> n1;
    n1.queue_push(1);
    n1.queue_push(2);
    n1.queue_show();
    queue<string> n2;
    n2.queue_push("hello");
    n2.queue_push(" world");
    n2.queue_show();
    return 0;
}

运行结果:

 思维导图

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

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

相关文章

【案例教学】华为云API对话机器人的魅力—体验AI垃圾分类机器人

云服务、API、SDK&#xff0c;调试&#xff0c;查看&#xff0c;我都行 阅读短文您可以学习到&#xff1a;人工智能AI自言语言的情感分析、文本分词、文本翻译 1 IntelliJ IDEA 之API插件介绍 API插件支持 VS Code IDE、IntelliJ IDEA等平台、以及华为云自研 CodeArts IDE&a…

Sudowrite:基于人工智能的AI写作文章生成工具

【 产品介绍】 名称 Sudowrite 成立/上线时间 2023年 具体描述 Sudowrite是一个基于GPT-3的人工智能写作工具&#xff0c;可以帮助你快速生成高质量的文本内容&#xff0c; 无论是小说、博客、营销文案还是学术论文。 Sudowrite可以根据你的输入和指…

BUSMASTER使用记录(一):基本收发、报文过滤、报文录制和数据回放

目录 一、概述二、基本收发2.1 连接设备2.2 接收2.3 发送 三、DBC加载和转换DBF文件四、报文过滤4.1 新增过滤器4.2 使能 五、报文录制/回放报文录制数据回放 一、概述 以往使用过的CAN盒虽然厂家不一样&#xff0c;但都兼容周立功的CANPro。这次使用的BusMaster&#xff0c;需…

ARM架构--栈

栈的概念 栈的本质就是一段内存&#xff0c;程序运行时用于保存一些临时数据 如局部变量、函数的参数、返回值、以及程序跳转时需要保护的寄存器等 在高级语言里面&#xff0c;操作的是变量。在ARM汇编里面&#xff0c;操作的是寄存器&#xff08;register&#xff09;、内存和…

LabVIEW对Table中同一行数据分多次增加

LabVIEW对Table中同一行数据分多次增加 在对多个设备采集数据&#xff0c;同时需要记录到表格中。很多时候多台数据并不是同时更新&#xff0c;比如有的是在开关之前读取更新&#xff0c;有的则是在开关闭合后更新。只是用Number Indicator的方式&#xff0c;需要很多个&#…

基于SSM的旅游网站系统

基于SSM的旅游网站系统【附源码文档】、前后端分离 开发语言&#xff1a;Java数据库&#xff1a;MySQL技术&#xff1a;SpringSpringMVCMyBatisVue工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 【主要功能】 角色&#xff1a;管理员、用户 管理员&#xff1a;用户管理、景点…

品牌 vs 营销:谁才是真正的推动商业增长的关键?

道叔曾经待过的公司&#xff0c;营销部和品牌部经常打架&#xff0c;明争暗斗&#xff0c;互相推诿&#xff0c;谁看谁不顺眼&#xff0c;沟通成本巨大....... 这两个本身关联密切、相辅相成的兄弟部门为什么会这样&#xff1f; 归根结底主要有以下三个原因&#xff1a; 1、…

【Linux系统编程】文件描述符与重定向

#include <unistd.h>int dup(int oldfd);int dup2(int oldfd, int newfd);dup函数是让最低位没有被使用的文件描述符也指向oldfd这个文件描述符所指向的文件&#xff0c;成功返回最低那个没有被使用的文件描述符&#xff0c;失败返回-1。 dup2函数是让newfd这个文件描述符…

IP代理安全吗?如何防止IP被限制访问?

你是否遇到过可以正常上网&#xff0c;但访问某个网站却被禁止&#xff1f;注册某个网站账号&#xff0c;却被封号&#xff1f;那都是因为IP出现问题&#xff01;您的IP地址透露很多关于您的信息&#xff0c;包括您的位置和互联网活动。 在本文中&#xff0c;我们将一起了解IP地…

第二章 进程与线程 二、进程的状态与转换

目录 一、进程的状态 1、创建态 2、就绪态 3、运行态 4、阻塞态 5、终止态 注意&#xff1a; 二、进程状态的转换 三、进程的组织 1、链接方式 2、索引方式 四、考点 一、进程的状态 1、创建态 &#xff08;1&#xff09;进程正在被创建时&#xff0c;它的状态是“…

排序算法-----希尔排序

目录 前言 希尔排序&#xff08;shell&#xff09; 排序原理 大致思路 示例 代码实现&#xff08;C语言&#xff09; 算法分析 时间复杂度 空间复杂度 稳定性 前言 前面我有一篇插入排序的详细的文章讲解&#xff08;链接&#xff1a;排序算法-----插入排序&#xff0…

⑧ 嵌套路由配置

这种就是路由嵌套 在index.js中加上三级页面 引入到二级导航里面 增加重定向配置 三级页面默认显示第一个页面信息 在这里插入图片描述

GNN动态顺序推荐Dynamic Graph Neural Networks for Sequential Recommendation

Dynamic Graph Neural Networks for Sequential Recommendation 文章目录 1. 背景2. 模型2.1 动态图构造2.2 子图采样2.3 动态图推荐网络2.3.1 消息传播机制2.3.2 Node updating 2.4 推荐和优化 1. 背景 协同过滤没有考虑用户商品交互的序列演变&#xff1b; 已经有一些RNN…

vue3项目中关于二进制导出(下载)txt ,适应于其他格式

<el-button type"info" click"exportClick" size"default">导出</el-button> 接口方法&#xff1a;getExportList import { tmUseDictApi } from //api/dict; const getExportList tmUseDictApi().getExportList //初始化数据 …

React 全栈体系(五)

第三章&#xff1a;React 应用(基于 React 脚手架) 一、使用 create-react-app 创建 react 应用 1. react 脚手架 xxx 脚手架: 用来帮助程序员快速创建一个基于 xxx 库的模板项目 包含了所有需要的配置&#xff08;语法检查、jsx 编译、devServer…&#xff09;下载好了所有…

【笔试强训选择题】Day42.习题(错题)解析

作者简介&#xff1a;大家好&#xff0c;我是未央&#xff1b; 博客首页&#xff1a;未央.303 系列专栏&#xff1a;笔试强训选择题 每日一句&#xff1a;人的一生&#xff0c;可以有所作为的时机只有一次&#xff0c;那就是现在&#xff01;&#xff01;&#xff01;&#xff…

深入理解JVM虚拟机第四篇:一些常用的JVM虚拟机(一)

一&#xff1a;Sun Classic VM虚拟机 早在1996年Java1.0版本的时候&#xff0c;Sun公司发布了一款名为Sun classic VM的Java虚拟机&#xff0c;它同时也是世界上第一款商用Java虚拟机&#xff0c;JDK1.4时完全被淘汰。 现在hotspot内置了此虚拟机。 这款虚拟机内部只提供解释器…

深入了解接口测试:Postman 接口测试指南

在现代软件开发生命周期中&#xff0c;接口测试是一个至关重要的部分。使用 Postman 这一工具&#xff0c;可以轻松地进行 接口测试。以下是一份简单的使用教程&#xff0c;帮助你快速上手。 安装 Postman 首先&#xff0c;你需要在电脑上安装 Postman。你可以从官网上下载并…

玩转堆排序以及Topk问题——【数据结构】

W...Y的主页 &#x1f60a; 代码仓库分享 &#x1f495; 目录 堆排序 建堆 建堆的时间复杂度 Topk问题 学习了二叉树以及堆&#xff0c;今天我们来学习一下什么是堆排序以及经典二叉树问题——topk问题。 在学习开始我们先来回顾一下上篇博客中我们提到的堆&#xff0c;…

TypeScript函数详解

&#x1f3ac; 岸边的风&#xff1a;个人主页 &#x1f525; 个人专栏 :《 VUE 》 《 javaScript 》 ⛺️ 生活的理想&#xff0c;就是为了理想的生活 ! 目录 函数声明 函数表达式 可选参数和默认参数 剩余参数&#xff08;Rest Parameters&#xff09; this和箭头函数 …