2024.9.3 作业

news2024/11/15 1:48:18

自己封装 栈和队列

#include <iostream>

using namespace std;

class mystack
{
private:
    int *data;
    int size;
    int top;
public:
    //无参构造
    mystack():size(10)
    {
        data = new int[size];
        top = -1;
        size =10;
    }

    //有参构造
    mystack(int s)
    {
        data = new int[s];
        top = -1;
        size = s;
    }

    //赋值
    mystack &operator=(mystack &R)
    {
        delete []this;
        data = new int[R.size];
        size = R.size;
        top = R.top;
        return *this;
    }

    //访问栈顶元素
    int gettop()
    {
        return data[top];
    }

    //判空
    bool empty()
    {
        return top==-1;
    }

    //求最大容量
    int getsize()
    {
        return size;
    }

    //向栈顶插入元素
    void push(int a)
    {
        if(top==size-1)
        {
            expend();  //二倍扩容
        }
        data[top+1] = a;
        top++;
    }

    //删除栈顶元素
    void pop()
    {
        data[top] = 0;
        top--;
    }

    //输出栈中元素
    void show()
    {
        for(int i=0;i<=top;i++)
        {
            cout<<data[i]<<" ";
        }
        cout<<endl;
    }

    //二倍扩容
    void expend()
    {
        int *temp = new int[size*2];
        for(int i=0;i<size;i++)
        {
            temp[i] = data[i];
        }
        delete []data;
        data = temp;
        size = size*2;
    }
};

int main()
{
    mystack s(3);
    s.push(99);
    s.push(77);
    s.push(88);
    //s.pop();
    s.show();
    cout<<"size="<<s.getsize()<<endl;
    s.push(66);
    s.show();
    cout<<"size="<<s.getsize()<<endl;
    return 0;
}
#include <iostream>

using namespace std;

class myqueue
{
private:
    int *data;
    int size;
    int front;
    int tail;
public:
    //无参构造
    myqueue():size(10)
    {
        data = new int[size];
        size =10;
        front = 0;
        tail = 0;
    }

    //有参构造
    myqueue(int s)
    {
        data = new int[s];
        size = s;
        front = 0;
        tail = 0;
    }

    //赋值
    myqueue &operator=(myqueue &R)
    {
        delete []this;
        data = new int[R.size];
        size = R.size;
        front = R.front;
        tail = R.tail;
        return *this;
    }

    //访问第一个元素
    int getfront()
    {
        if(empty())
        {
            cout<<"队列中没有元素"<<endl;
            return -1;
        }
        return data[front];
    }

    //访问最后一个元素
    int back()
    {
        if(empty())
        {
            cout<<"队列中没有元素"<<endl;
            return -1;
        }
        return data[tail];
    }

    //判空
    bool empty()
    {
        return front==tail;
    }

    //判满
    bool full()
    {
        return (tail+1)%size == front;
    }

    //求最大容量
    int getsize()
    {
        return size;
    }

    //向队列尾部插入元素
    void push(int a)
    {
        if(full())
        {
            cout<<"队列满了"<<endl;
        }
        else
        {
            data[tail] = a;
            tail = (tail+1)%size;
        }
    }

    //删除首个元素
    void pop()
    {
        if(empty())
        {
            cout<<"队列为空"<<endl;
            return ;
        }
        data[front] = 0;
        front = (front+1)%size;
    }

    //输出栈中元素
    void show()
    {
        if(empty())
        {
            cout<<"队列为空"<<endl;
            return ;
        }
        for(int i=front;i!=tail;i=(i+1)%size)
        {
            cout<<data[i]<<" ";
        }
        cout<<endl;
    }
};

int main()
{
    myqueue q1(4);
    q1.push(66);
    q1.push(77);
    q1.push(88);
    q1.show();
    q1.pop();
    q1.push(99);
    q1.show();

    return 0;
}

思维导图

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

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

相关文章

智慧医院是什么?建设智慧医院的关键步骤

智慧医院是什么&#xff1f; 智慧医院是一种新型的医疗机构&#xff0c;它利用先进的信息技术、数据分析和智能化系统&#xff0c;优化医院的管理和服务流程&#xff0c;提高医疗质量和效率。在智慧医院中&#xff0c;所有的运营和管理环节都可以通过数据驱动的方式来实现优化…

【网络安全】服务基础第一阶段——第十节:Windows系统管理基础---- 组策略高级应用

目录 一、组策略的基本概念 1.1 组策略的基本概念 1.1.1 组策略对象 1.2 配置 1.2.1 计算机配置&#xff08;Computer Configuration&#xff09; 1.2.2 用户配置&#xff08;User Configuration&#xff09; 1.3 作用范围 1.4 继承和优先级 1.4.1 继承&#xff08;In…

【AI】Pytorch_模型构建

建议点赞收藏关注&#xff01;持续更新至pytorch大部分内容更完。 本文已达到10w字&#xff0c;故按模块拆开&#xff0c;详见目录导航。 整体框架如下 数据及预处理 模型及其构建 损失函数及优化器 本节目录 模型线性回归逻辑回归LeNetAlexNet 构建模块组织复杂网络初始化网络…

SpringBoot学习(3)(配置文件的基本使用)

1、初步大致学习方向&#xff08;基础&#xff09; 配置文件整合MyBatisBean管理&#xff08;主要学习如何管理第三方bean对象&#xff1f;&#xff1f;如导入一个jar包&#xff0c;这个jar包中的一些对象&#xff0c;如何注入到Ioc容器里&#xff09;自动配置原理&#xff08;…

史上最全的Mysql索引教程

一、什么是索引 1.1 索引简介 索引是数据库中用来提高数据检索效率的数据结构。它类似于书籍的目录&#xff0c;可以帮助用户快速找到所需的数据&#xff0c;而不必扫描整个数据集。在数据库系统中&#xff0c;索引可以显著提高查询性能。 所谓的存储引擎&#xff0c;说白了…

【mysql】SQL语言的概述

基本select语句的使用&#xff1a; SQL概述&#xff1a; 1946年&#xff0c;第一台电脑诞生了&#xff0c;有很多基础技术在里面&#xff0c;但是在几十年来&#xff0c;保留下来的技术SQL就是其中之一&#xff0c; 1974年的时候&#xff0c;IBM的研究员发布了一篇揭开数据库…

代码随想录算法训练营第35天|背包问题基础、46. 携带研究材料(01背包二维解法)(01背包一维解法)(acm)、416. 分割等和子集

目录 0、背包问题基础01背包 46. 携带研究材料&#xff08;01背包&#xff09;1、题目描述2、思路3、code&#xff08;二维解法&#xff09;3-1、code&#xff08;一维解法&#xff09;4、复杂度分析 416. 分割等和子集1、题目描述2、思路3、code4、复杂度分析 0、背包问题基础…

如何有效地管理个人时间:策略与技巧

在快节奏的生活环境中&#xff0c;时间成为了最宝贵的资源之一。有效地管理时间不仅能提高工作效率&#xff0c;还能提升生活质量&#xff0c;使你有更多的时间投入到家庭、爱好和个人成长中去。本文将分享一些实用的时间管理技巧&#xff0c;帮助你更好地安排每日事务。 时间…

[HZNUCTF 2023 preliminary]easyAPK-快坚持不下去的第三天

第一做安卓题&#xff0c;前提jadx,java环境&#xff0c;模拟器&#xff0c;我配了好久&#xff0c; 这段代码实现了一个简单的登录界面&#xff0c;用户需要输入用户名和密码。用户名和密码会与预设的硬编码值进行比较&#xff0c;登录成功后会启动另一个 Activity。如果密码错…

TS 学习(一)

如果我们在 ts 中写 不用运行就能在文件中报错 ts 是一种静态类型的检查 能将运行时出现的错误前置 一般不用 命令行编译 ts 转换成 js 将中文转码 tsc index&#xff08;.ts&#xff09; 输入命令生成 配置文件 能在中间进行 配置转换成 js 的哪个规范 es5 还是 6 和其它转…

鸿蒙(API 12 Beta6版)图形【过度绘制调试使用指导】方舟2D图形服务

当应用页面布局的嵌套程度过深时&#xff0c;应用渲染阶段会存在一些组件的绘制指令被其他组件的绘制指令部分或完全覆盖遮挡的情况&#xff0c;造成冗余的cpu、gpu等计算资源的使用。这种一个屏幕上的像素点被重复绘制了多次的情况被称为过度绘制&#xff08;Overdraw&#xf…

Vite - 兼容旧版浏览器 plugin-legacy(2)

目录 1&#xff0c;问题2&#xff0c;解决3&#xff0c;String 其他新增 API 的版本 接上文 Vite - 兼容旧版浏览器 plugin-legacy&#xff08;1&#xff09; 1&#xff0c;问题 客户浏览器报错&#xff0c;不支持 replaceAll 方法。 该方法在 query-string 依赖内部使用了。…

通过生日计算年龄

// 获取当前月 function getDate(date) {let d new Date(date);// 将日期设置为下月一号d.setMonth(d.getMonth() 1);d.setDate(1);// 获取本月最后一天d.setDate(d.getDate() - 1);return d.getDate(); } // 获取年龄 传出生日期和当前日期&#xff0c;当前日期可以不用传 f…

双指针(1)_数组分块_移动零问题

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 双指针(1)_数组分块_移动零问题 收录于专栏【经典算法练习】 本专栏旨在分享学习C的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 1.…

ELK学习笔记(二)——使用K8S部署Kibana8.15.0

上篇文章我们完成了&#xff0c;ES的集群部署&#xff0c;如果还没有看过上篇文章的兄弟&#xff0c;可以去看看。 ELK学习笔记&#xff08;一&#xff09;——使用K8S部署ElasticSearch8.15.0集群 话不多说&#xff0c;接下来直接进入kibana的搭建 一、下载镜像 #1、下载官方…

hackme靶机通关攻略

1、登录靶机&#xff0c;查询是否有注入点 2、判断闭合方式 输入OSINT and 11 # 输入OSINT and 12 # 得出闭合方式为单引号 2、查询数据库名 输入-1 union select database(),2,3 # 3、查询数据库中的表 输入-1 union select group_concat(table_name),2,3 from informa…

搜维尔科技:数据手套+机械手遥操作,五指触感灵巧手解决方案!

本灵巧手模仿人手的自由度分配及相关运动学参数进行设计的灵巧手&#xff0c;整手的手指设计采用了模块化的思想。整机重量轻&#xff0c;单指指尖抓取力强&#xff0c;五指灵巧手作为人体机器人或者机械臂末端操作工具&#xff0c;在工业生产的特殊环境中&#xff0c;对复杂形…

Spring事务(2)——@Transaction详解

目录 一、rollbackFor 结论&#xff1a; 二、事务隔离级别 1、MySQL 事务隔离级别&#xff08;回顾&#xff09; 2、Spring 事务隔离级别 三、Spring 事务传播机制 1、什么是事务传播机制&#xff1f; 2、事务的传播机制有哪些&#xff1f; 3、Spring 事务传播机制使用…

基于SpringBoot技术的家具网站设计与实现

你好呀&#xff0c;我是计算机学姐码农小野&#xff01;如果有相关需求&#xff0c;可以私信联系我。 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SpringBoot框架 工具&#xff1a;Eclipse、Navicat 系统展示 首页 家具详情界面 购物车界面 订单…

Python 数据分析— Pandas 基本操作(上)

文章目录 学习内容&#xff1a;一、Series 创建及操作二、DataFram 的创建与操作三、Pandas 的读写操作四、选择指定行列数据 学习内容&#xff1a; 一、Series 创建及操作 ** Series : Pandas 的一种数据结构形式&#xff0c;可理解为含有索引的一维数组。** **&#xff08;…