c++day3 手动封装一个顺序表(SeqList),分文件编译实现

要求:

有私有成员:顺序表数组的起始地址 ptr、 顺序表的总长度:size、顺序表的实际长度:len

成员函数:初始化 init(int n)

判空:empty

判满:full

尾插:push_back

插入:insert(int index)

任意位置删除:erase(int index)

尾删: pop_back

求长度:size()

获取任意位置元素:& at(int inex)

将顺序表进行排序:sort(bool flag) //flag 为真,表示升序,否则是降序

seqlist.h

#ifndef SEQLIST_H
#define SEQLIST_H
 
 
//typedef int datatype;        //类型重命名
using datatype = int;
 
 
 
 
//封装一个顺序表
class SeqList
{
private:
    datatype *ptr;        //指向堆区空间的起始地址
    int size;             //总长度
    int len = 0;          //当前顺序表实际长度
 
 
public:
    void init(int n);
 
    bool empty();
 
    bool full();
 
    void push_back(datatype e);
 
    void insert(int index);//插入
 
    void erase(int index); //任意位置删除
 
    void pop_back();       //尾删
 
    void size_1();
 
    int & at(int index); //获取任意位置元素
 
    void sort(bool flag);   //真升序,否则降序
 
    void show();
 
 
};
#endif // SEQLIST_H

seqlist.cpp

#include <iostream>
 
using namespace std;
#include "seqlist.h"
 
void SeqList::init(int n)
{
       //在堆区申请出一个长度为n的空间,将其实地址赋值给ptr
       this->ptr = new datatype[n];
 
 
       //给len进行初始化
       this->len = 0;
       this->size = n;
}
 
bool SeqList::empty()
{
    return this->len == 0;
}
 
bool SeqList::full()
{
    return this->len == this->size;
}
 
void SeqList::push_back(datatype e)
{
    //判断是否满了
    if(this->full())
    {
        return ;
    }
 
 
    this->ptr[len++] = e;
 
}
 
 
void SeqList::show()
{
    //判空
    if(this->empty())
    {
        return ;
    }
 
    cout<<"当前顺序表中的元素分别是:";
    for(int i=0; i<this->len; i++)
    {
        cout<<*(ptr+i)<<" ";
    }
    cout<<endl;
}
void SeqList::insert(int index)
{
    if(this->empty()||this->full()||index<0||index>this->len)
    {
        return ;
    }
    int key;
    cout<<"第"<<index+1<<"个你想插入的值:";
    cin>>key;
 
    int n = this->len;
    int i = index;
    while(i<=n)
    {
        this->ptr[n+1]=this->ptr[n];
        n--;
    }
    this->ptr[index]=key;
 
    this->len++;
}
 
void SeqList::erase(int index)
{
    if(this->empty()||index<0||index>this->len)
    {
        return ;
    }
    int n = this->len;
    int i = index;
    while (i<=n)
    {
        this->ptr[i]=this->ptr[i+1];
        i++;
    }
 
    this->len--;
 
}
 
void SeqList::pop_back()
{
    if(this->empty())
    {
        return ;
    }
 
    this->len--;
}
 
void SeqList::size_1()
{
    if(this->empty())
    {
        return ;
    }
 
    cout<<"顺序表元素个数:"<<this->len+1<<endl;
 
}
 
int error =-1;
int & SeqList::at(int index)
{
 
    if(this->empty()||index<0||index>=this->len)
    {
 
        cout<<"越界"<<endl;
        return error;
    }
 
    return this->ptr[index];
 
}
 
void SeqList::sort(bool flag)
{
    if(this->empty())
    {
        return ;
    }
    int i = 0,j,index;
    int n = this->len;
 
 
    while(i<n)
    {
        index = i;
        j=i;
        while(j<n)
        {
            if(flag)
            {
                if(this->ptr[index]>this->ptr[j])
                {
                    index = j;
                }
            }
            else{
                if(this->ptr[index]<this->ptr[j])
                {
                    index = j;
                }
 
            }
            j++;
        }
        if(index!=i)
        {
            int temp = this->ptr[index];
            this->ptr[index] = this->ptr[i];
            this->ptr[i] = temp;
 
        }
        i++;
 
 
 
    }
}

main.cpp

#include <iostream>
#include "seqlist.h"
using namespace std;
 
int main()
{
 
    SeqList sl;           //实例化一个顺序表对象
    sl.init(5);            //申请空间
    sl.push_back(1);
    sl.push_back(3);
    sl.push_back(5);
 
    sl.show();
 
    sl.insert(1);
    sl.insert(1);
    cout<<"插入后数组:"<<endl;
    sl.show();
 
//    sl.erase(1);
//    cout<<"删除后数组:"<<endl;
//    sl.show();
 
//    sl.pop_back();
//    cout<<"尾删后数组:"<<endl;
//    sl.show();
 
    int pos = sl.at(2);
    cout<<"该位置的值:"<<pos<<endl;
 
    sl.sort(1);
    cout<<"升序排序后:"<<endl;
    sl.show();
 
    sl.sort(0);
    cout<<"降序排序后:"<<endl;
    sl.show();
 
    return 0;
}
 

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

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

相关文章

进程间的通信4 共享内存

共享内存 1.共享内存简介 共享内存是将分配的物理空间直接映射到进程的用户虚拟地址空间中&#xff0c;减少数据在内核空间缓存共享内存是一种效率较高的进程间通讯的方式在 Linux 系统中通过 ipcs -m 查看所有的共享内存 共享内存模型图 2.共享内存的创建 1.函数头文件 #…

【如何在 Windows 10 主机上通过 VMware 安装 Windows 11 虚拟机,并共享主机网络】

环境说明 主机操作系统&#xff1a;Windows 10虚拟机操作系统&#xff1a;Windows 11虚拟机软件&#xff1a;VMware 步骤一&#xff1a;确保主机&#xff08;Windows 10&#xff09;网络连接正常 启动网络加速软件&#xff1a;在主机上启动软件&#xff0c;确保主机可以正常访…

JavaEE: 深入探索TCP网络编程的奇妙世界(三)

文章目录 TCP核心机制TCP核心机制三: 连接管理建立连接(三次握手)断开连接(四次挥手)三次握手/四次挥手 流程简图 TCP核心机制 书接上文~ TCP核心机制三: 连接管理 建立连接(三次握手),断开连接(四次挥手). 这里的次数指的是网络通信的次数,挥手/握手是形象的比喻(handshake…

基于SpringBoot+Vue的智慧物业管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、SSM项目源码 精品专栏&#xff1a;Java精选实战项目源码、Python精…

SpringBoot3核心特性-核心原理

目录 传送门前言一、事件和监听器1、生命周期监听2、事件触发时机 二、自动配置原理1、入门理解1.1、自动配置流程1.2、SPI机制1.3、功能开关 2、进阶理解2.1、 SpringBootApplication2.2、 完整启动加载流程 三、自定义starter1、业务代码2、基本抽取3、使用EnableXxx机制4、完…

SaaS软件的配置化平台是如何实现个性化定制的?

SaaS&#xff08;Software as a Service&#xff0c;软件即服务&#xff09;是一种通过互联网提供软件的模式&#xff0c;用户无需安装和维护任何复杂的基础设施&#xff0c;只需通过网络连接即可使用软件。SaaS 供应商负责软件的维护、升级和可用性&#xff0c;用户则通过订阅…

智能体时代,AI正从“神坛”走向“人间”

从通用大模型到行业大模型&#xff1a;AI智能体引领新风口 在人工智能领域&#xff0c;一场深刻的变革正悄然发生。从昔日高高在上的通用大模型&#xff0c;到如今愈发接地气的行业大模型&#xff0c;AI的风向标已经鲜明地指向了AI智能体&#xff08;AI Agent&#xff09;&…

APO v0.4.0 发布:新增影响面分析;新增调用数据库指标;优化告警事件关联展示

APO 新版本 v0.4.0 正式发布&#xff01;本次更新主要包含以下内容&#xff1a; 新增影响面分析&#xff0c;识别服务端点对服务入口的影响 服务入口是指业务被访问时调用的第一个服务端点&#xff0c;在调用拓扑图中处于最上游。服务入口直接反映了系统对外提供服务的状态&a…

基于SpringBoot+Vue+MySQL的手机销售管理系统

系统展示 用户前台界面 管理员后台界面 商家后台界面 系统背景 随着智能手机的普及和市场竞争的日益激烈&#xff0c;手机销售行业面临着前所未有的挑战与机遇。传统的手工记录和简单的电子表格管理方式已难以满足现代手机销售业务的需求&#xff0c;销售数据的混乱和管理效率低…

(done) 声音信号处理基础知识(2) (重点知识:pitch)(Sound Waveforms)

来源&#xff1a;https://www.youtube.com/watch?vbnHHVo3j124 复习物理知识&#xff1a; 声音由物体的振动产生 物体振动会导致空气分支振荡 某一处的空气气压变化会创造一个波 声音是机械波 空气的振荡在空间中传递 能量从空间中的一个点到另一个点 机械波需要媒介&#x…

DBNet 博客转载

论文地址&#xff1a;https://arxiv.org/abs/1911.08947 最后的文字概率还需要扩张d https://blog.csdn.net/weixin_46505265/article/details/134836652 https://paddlepedia.readthedocs.io/en/latest/tutorials/computer_vision/OCR/OCR_Detection/DBNet.html

ThreadLocal与AsyncLocal

简介 ThreadLocal 用于在多线程环境中创建线程局部变量&#xff0c;可以让每个线程独立地访问自己的变量副本&#xff0c;互不影响。 而 AsyncLocal 是 ThreadLocal 的异步版本&#xff0c;专门用于异步编程场景&#xff0c;在异步操作中它可以正确处理上下文切换。 ThreadLo…

【Python】探索 Elpy:Emacs 中的 Python 开发环境

可以短时间不开心&#xff0c;但别长时间不清醒。 对于使用 Emacs 编辑器的 Python 开发者来说&#xff0c;Elpy 是一个强大的集成开发环境&#xff08;IDE&#xff09;&#xff0c;它通过整合多个 Emacs Lisp 和 Python 包&#xff0c;提供了一套完整的 Python 编程支持。本文…

MySQL基础篇的补充

前言&#xff1a; 查询语句的书写顺序 select > from > where > group by > having > order by > limit 查询语句的执行顺序 from > where > group by > having > select > order by > limit 这个很重要&#xff0c;提前再复习一下。…

vue入门小练习

文章目录 1.案例需求2.编程思路3.案例源码4.小结 1.案例需求 一个简易的计算器&#xff0c;其效果如下&#xff1a; 图片切换&#xff0c;其效果如下&#xff1a; 简易记事本&#xff0c;其效果如下&#xff1a; 2.编程思路 1.这个Vue.js应用实现了一个简单的计算器&#x…

检索索引对象中的重复值、删除重复值pandas.Index.duplicated

【小白从小学Python、C、Java】 【考研初试复试毕业设计】 【Python基础AI数据分析】 检索索引对象中的重复值、删除重复值 pandas.Index.duplicated [太阳]选择题 根据代码&#xff0c;下列哪个选项正确表示了去重后的结果&#xff1f; import pandas as pd idx pd.Index([1,…

图书管理系统小程序的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;用户管理&#xff0c;图书分类管理&#xff0c;图书信息管理&#xff0c;我的待还处管理&#xff0c;图书归还管理&#xff0c;催还提醒管理&#xff0c;系统管理 微信端账号功能包括&#xff1a;系统…

如何实现接口幂等性?

概述 幂等&#xff0c;英文idempotent [aɪdempətənt] 幂等这个词源自数学&#xff0c;是数学中的一个概念&#xff0c;常见于抽象代数中&#xff0c;表达的是N次变换与1次变换的结果相同&#xff0c;在计算机的各个领域都借用了该概念 幂等函数或幂等方法&#xff0c;是指…

stm32单片机个人学习笔记6(EXTI外部中断)

前言 本篇文章属于stm32单片机&#xff08;以下简称单片机&#xff09;的学习笔记&#xff0c;来源于B站教学视频。下面是这位up主的视频链接。本文为个人学习笔记&#xff0c;只能做参考&#xff0c;细节方面建议观看视频&#xff0c;肯定受益匪浅。 STM32入门教程-2023版 细…

大模型Qwen2.5 家族的最新成员

阿里今天发布了 Qwen 家族的最新成员&#xff1a;Qwen2.5&#xff0c;包括语言模型 Qwen2.5&#xff0c;以及专门针对编程的 Qwen2.5-Coder 和数学的 Qwen2.5-Math 模型。 所有开放权重的模型都是稠密的、decoder-only 的语言模型&#xff0c;提供多种不同规模的版本&#xff…