9月3c++

news2024/9/22 2:23:15

封装栈和队列

队列

#include <iostream>
#include <cstring>
using namespace std;
class Myqueue
{
private:
    int data[256];
    int size=0;
public:
    Myqueue(){}//无参构造
    ~Myqueue(){}//析构
    //拷贝赋值
    Myqueue & operator=(const Myqueue &other)
    {
        if(this!=&other)
        {
            memset(this->data,0,this->size);
            for(int i=0;i<size;i++)
            {
                this->data[i]=other.data[i];
            }
        }
        return *this;
    }
    //判空
    bool queue_empty()
    {
        return size==0;
    }
    //访问第一个元素
    int queue_front()
    {
        if(queue_empty())
        {
            cout<<"队列为空"<<endl;
            return 0;
        }
        return data[0];
    }
    //访问最后一个元素
    int queue_back()
    {
        if(queue_empty())
        {
            cout<<"队列为空"<<endl;
            return 0;
        }
        return data[size-1];
    }

    int queue_size()
    {
        return size;
    }
    //队尾插入元素
    Myqueue & queue_push(int n)
    {
        if(size==256)
        {
            cout<<"队列已满"<<endl;
            return *this;
        }
        data[size]=n;
        size++;
        return *this;
    }
    //删除首个元素
    Myqueue & queue_pop()
    {
        if(queue_empty())
        {
            cout<<"队列已空"<<endl;
            return *this;
        }
        for(int i=0;i<size-1;i++)
        {
            data[i]=data[i+1];
        }
        data[size-1]=0;
        size--;
        return *this;
    }
    //遍历输出队列
    void show()
    {
        if(queue_empty())
        {
            cout<<"队列空"<<endl;
            return;
        }
        for(int i=0;i<size;i++)
        {
            cout<<data[i]<<" ";
        }
        cout<<endl;
    }
};

int main()
{

    Myqueue t,p;
    t.queue_push(1);
    t.queue_push(2);
    t.queue_push(3);
    t.show();
    cout<<"********************"<<endl;
    p.queue_push(7);
    p.queue_push(8);
    p.queue_push(9);
    p.show();
    cout<<"*********************"<<endl;
    t=p;
    t.show();
    cout<<"队列第一个元素 "<<t.queue_front()<<" 队列最后一个元素 "<<t.queue_back()<<" 元素个数 "<<t.queue_size()<<endl;
    cout<<"*********************"<<endl;
    t.queue_pop();
    t.show();
    cout<<"队列第一个元素 "<<t.queue_front()<<" 队列最后一个元素 "<<t.queue_back()<<" 元素个数 "<<t.queue_size()<<endl;
    return 0;
}

 

#include <iostream>
#include <cstring>
using namespace std;
//封装栈
class Mystack
{
private:
    int data[256];//数组
    int top=-1;//栈顶位置
public:
    Mystack(){};//无参构造
    ~Mystack(){};//析构函数
    //拷贝赋值
    Mystack & operator=(const Mystack &other)
    {
        if(this!=&other)
        {
            memset(data,0,this->top+1);//初始化原栈
            this->top=other.top;//修改栈顶位置
            //修改各元素
            for(int i=0;i<=other.top;i++)
            {
                this->data[i]=other.data[i];
            }
        }
        return *this;
    }
    //判空
    bool stack_empty()
    {
        return top==-1;//判断栈顶是否为-1
    }
    //返回栈顶位置
    int stack_size()
    {
        return top+1;//返回栈顶位置
    }
    //访问栈顶元素
    int stack_top()
    {
        //判空
        if(stack_empty())
        {
            cout<<"栈为空"<<endl;
            return 0;
        }
        return data[top];
    }
    //入栈
    Mystack & stack_push(int n)
    {
        if(top==255)
        {
            cout<<"栈已满"<<endl;
            return *this;
        }
        //栈顶位置加1,栈顶位置赋值
        top++;
        this->data[top]=n;
        return *this;
    }
    //出栈
    Mystack & stack_pop()
    {
        if(stack_empty())
        {
            cout<<"栈为空"<<endl;
            return *this;
        }
        data[top]=0;//栈顶元素为0
        top--;//栈顶位置减一
        return *this;
    }
    //遍历输出栈
    void show()
    {
        if(stack_empty())
        {
            cout<<"栈空"<<endl;
            return;
        }
        for(int i=0;i<=top;i++)
        {
            cout<<data[i]<<" ";
        }
        cout<<endl;
    }
};

int main()
{
    Mystack t,p;
    t.stack_push(1);
    t.stack_push(2);
    t.stack_push(3);
    t.show();
    cout<<"********************"<<endl;
    p.stack_push(7);
    p.stack_push(8);
    p.stack_push(9);
    p.show();
    cout<<"*********************"<<endl;
    t=p;
    t.show();
    cout<<"栈顶元素 "<<t.stack_top()<<" 元素个数 "<<t.stack_size()<<endl;
    cout<<"*********************"<<endl;
    t.stack_pop();
    t.show();
    cout<<"栈顶元素 "<<t.stack_top()<<" 元素个数 "<<t.stack_size()<<endl;
    return 0;
}

 

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

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

相关文章

C++ ─── List的模拟实现

一&#xff0c; List的模拟实现 List 是一个双向循环链表,由于List的节点不连续&#xff0c;不能用节点指针直接作为迭代器&#xff0c;因此我们要对结点指针封装&#xff0c;来实现迭代器的作用。 迭代器有两种实现方式&#xff0c;具体应根据容器底层数据结构实现&#xff1…

15、VSCode自定义Markwown编辑环境

前言 &#xff1a;Visual Studio Code (VSCode) 是微软推出的一款开源编辑器&#xff0c;使用 Electron 打造&#xff0c;与 Atom 齐名&#xff0c;不过随着 Atom 社区的渐渐缩小&#xff0c;VSCode 的影响力开始越来越大了。VSCode 内置了 Markdown 语言及预览的支持&#xff…

每周12600元奖金池,邀你与昇腾算力共舞,openMind开发者盛宴启幕!

小伙伴们&#xff0c;是否瞬间被这个标题唤醒了在OpenI启智社区“我为开源打榜狂”黄金时代的温馨记忆&#xff1f;打榜活动虽已谢幕&#xff0c;但大家相伴度过12期的那份激情与创新的共鸣&#xff0c;促使OpenI启智社区在国产算力崛起的浪潮中勇立潮头&#xff0c;推出了“芯…

JavaScript是什么

前言 初始JavaScript JavaScript是什么 JavaScript (简称 JS) 是世界上最流行的编程语言之一 是一个脚本语言, 通过解释器运行 主要在客户端(浏览器)上运行, 现在也可以基于 node.js 在服务器端运行. JavaScript 最初只是为了完成简单的表单验证(验证数据合法性), 结果后…

git 回滚的三种方式

按照从旧到新的顺序 你依次提交了 1 2 3 4 5 现在你想回到1 如何操作 第一种方法 hard reset git reset --hard 执行命令后 你会发现 效果实现了 东西都回到了那次更改 但是2345的更改都没了 并且你会发现 你有更新 这是因为这个hard reset 只会改本地的 远程的不改 一更新就…

7.Lab Six —— Cow Fork

首先切换分支到cow git checkout cow make clean Implement copy-on write 实现写时复制&#xff0c;为了测试方案&#xff0c;以及提供了一个cowtest的xv6程序&#xff0c;位于user/cowtest.c当中 课程给了一个合理的攻克计划&#xff1a; 修改uvmcopy()将父进程的物理页映…

GO 下载依赖改成国内代理

改成我们国内可用的代理地址 在命令提示符输入&#xff1a; 1 go env -w GOPROXYhttps://goproxy.cn 然后再做各种操作就可以成功了 另外一个问题&#xff1a; 手动下载某些依赖包&#xff0c;但是goland一直无法识别。 删掉了GOPATH多余的路径。 另外&#xff0c;启用了…

STL—vector容器

目录 1、简单使用&#xff08;插入数据三种遍历方式&#xff09; 2、介绍 3、常用构造方法 3、扩容reserve和缩容shrink_to_fit 4、insert函数&#xff1a;在某个位置进行插入数据 5、vector使用库里面的find 6、vector< vector > 7、看源代码的技巧 1、简单使用&…

大二必做项目贪吃蛇超详解之下篇游戏核心逻辑实现

贪吃蛇系列文章 上篇win32库介绍中篇设计与分析下篇游戏主逻辑 可以在Gitee上获取贪吃蛇代码。 文章目录 贪吃蛇系列文章5. 核心逻辑实现分析5. 3 GameRun5. 3. 1 PrintScore5. 3. 2 CheckVK5. 3. 3 BuyNewNode5. 3. 4 NextIsFood5. 3. 4 EatFood5. 3. 5 NotFood5. 3. 6 Chec…

【OpenLayers 进阶】添加滤镜改变底图样式

目录 一、前言二、准备工作三、实现方式四、总结 一、前言 项目实施过程中&#xff0c;需要根据不同的业务场景需求变换地图样式。如果客户提供的底图服务或自建底图服务是类似Mapbox这种矢量切片&#xff0c;那只要按照需求配置不同的样式文件即可。如果没有矢量切片&#xff…

浅谈人工智能之Windows:基于ollama进行本地化大模型部署

浅谈人工智能之Windows&#xff1a;基于ollama进行本地化大模型部署 引言 随着人工智能技术的飞速发展&#xff0c;大型语言模型&#xff08;LLMs&#xff09;已经成为推动自然语言处理领域进步的关键力量。然而&#xff0c;传统的云部署方式可能带来数据隐私、成本以及访问速…

pikachu文件包含漏洞靶场通关攻略

本地文件包含 先上传一个jpg文件&#xff0c;内容写上<?php phpinfo();?> 上传成功并且知晓了文件的路径 返回本地上传&#xff0c;并../返回上级目录 可以看到我们的php语句已经生效 远程文件包含 在云服务器上创建一个php文件 然后打开pikachu的远程文件包含靶场&…

鸿蒙开发培训多少钱?

随着物联网技术的发展&#xff0c;HarmonyOS(鸿蒙系统)作为华为推出的一款面向全场景的分布式操作系统&#xff0c;正在逐步成为开发者们关注的焦点。对于那些想要进入这个新兴领域的开发者来说&#xff0c;参加鸿蒙开发培训是一个不错的选择。那么&#xff0c;这样的培训究竟需…

【Hadoop|HDFS篇】HDFS概述

1. HDFS产出背景及定义 1.1 HDFS产生背景 随着数据量越来越大&#xff0c;在一个操作系统存不下所有的数据&#xff0c;那么就分配到更多的操作系 统管理的磁盘中&#xff0c;但是不方便管理和维护&#xff0c;迫切需要一种系统来管理多台机器上的文件&#xff0c;这 就是分布…

Oracle授权如何购买?多少钱?如何计算?

前言 作为DBA时常也会遇到一些商务的问题&#xff0c;比如购买Oracle 的授权&#xff0c;比如老板问用oracle有没有法律风险&#xff0c;这个组件是否收费&#xff1f;如何计算授权数&#xff1f;等等&#xff0c;本文根据博主的经验和一些Oracle公开的资料&#xff0c;来做一个…

DBNET文字检测

原文:DBNET文字检测 - 知乎 (zhihu.com) 一、DBNET介绍 DBNET核心采用的是基于分割的做法进行文本检测,即将每个文本块都进行语义分割,然后对分割概率图进行简单二值化、最终转化得为box或者poly格式的检测结果。除去网络设计方面的差异,最大特点是引入了Differentiable …

Python 从入门到实战6(二维列表)

我们的目标是&#xff1a;通过这一套资料学习下来&#xff0c;通过熟练掌握python基础&#xff0c;然后结合经典实例、实践相结合&#xff0c;使我们完全掌握python&#xff0c;并做到独立完成项目开发的能力。 之前的文章我们通过举例学习了python 中列表的相关操作&#xff0…

什么是阿凡达2.0直播模式?

要了解什么是什么是阿凡达2.0直播模式,首先要了解什么是的阿凡达直播模式。 我们知道真人直播&#xff0c;播不了几个小时&#xff0c;主播就讲累了。且真人主播的价格又贵&#xff0c;以小时计费。所以很多数字人厂商推出了数字人直播。用数字人代替真人直播。在前几年的时候…

强烈建议!重罚自燃车企

文 | AUTO芯球 作者 | 雷慢 想想就叫人害怕啊&#xff0c; 广东惠州电车自燃那个事&#xff0c;你们看了吗 3辆汽车和多辆电动自行车被烧毁&#xff0c;住宅变危房&#xff0c; 最触目惊心的还是浓烟&#xff0c;许多住户咳呛不止&#xff0c; 周边小区也惨遭浓烟毒害&…

Css:css的属性选择器vs关系选择器及css中伪元素

css的属性选择器&#xff1a; 注&#xff1a;属性值只能由数字&#xff0c;字母&#xff0c;下划线&#xff0c;中划线组成&#xff0c;并且不能以数字开头。 1、[属性] 选择含有指定属性的元素&#xff0c;用[]中括号表示。 <style> [title]{color:red;} p[title]{col…