当前位置: 首页 > article >正文

8月28日

思维导图

作业:

使用C++手动封装一个顺序表,包含成员数组一个,成员变量N个

代码:

#include <iostream>

using namespace std;

using datatype = int;
#define MAX 30

struct SeqList
{
    private:
        datatype *data;
        int size = 0;
        int len = 0;

    public:
        void init(int s)
        {
            size = s;
            data = new datatype(size);
        }

        //判空函数
        bool empty();
        //判满函数
        bool full();
        //添加数据函数
        bool add(datatype e);
        //求当前数据表的实际长度
        int length();

        //任意位置插入函数
        bool insert_pos(int pos,datatype e);
        //任意位置删除函数
        bool deiete_pos(int pos);
        //访问容器中任意一个元素 at
        datatype &at(int index);

        //查看数组
        void show();


};

//判空函数
bool SeqList::empty()
{
    if(len == 0)
    {
        return 1;
    }
    else
    {
        return 0;
    }
}

//判满函数
bool SeqList::full()
{
    if(len == size)
    {
        return 1;
    }
    else
    {
        return 0;
    }
}

//添加数据函数
bool SeqList::add(datatype e)
{
    if(full())
    {
        cout<<"添加失败"<<endl;
        return 0;
    }

    data[len] = e;

    len++;
    return 1;
}

//求当前数据表的实际长度
int SeqList::length()
{
    return len;
}

//任意位置插入函数
bool SeqList::insert_pos(int pos,datatype e)
{
    if(full() || pos<0 || pos>len)
    {
        cout<<"插入失败"<<endl;
        return 0;
    }

    for(int i=len-1;i>=pos;i--)
    {
        data[i+1] = data[i];//将数据后移
    }

    data[pos] = e;

    len++;

    cout<<"插入成功"<<endl;
    return 1;
}

//任意位置删除函数
bool SeqList::deiete_pos(int pos)
{
    if(empty() || pos<0 || pos>len)
    {
        cout<<"插入失败"<<endl;
        return 0;
    }

    for(int i=pos+1;i<len;i++)
    {
        data[i-1] = data[i];//将数据后移
    }

    len--;

    cout<<"删除成功"<<endl;
    return 1;
}

//访问容器中任意一个元素 at
datatype &SeqList::at(int index)
{
     return data[index];

}

//查看顺序表
void SeqList::show()
{
    cout<<"当前顺序表为:";
    for(int i=0;i<len;i++)
    {
        cout<<data[i]<<" ";
    }
    cout<<endl;
}


int main()
{
    SeqList s1;
    s1.init(MAX);

    //添加数据
    s1.add(1);
    s1.add(2);
    s1.add(3);
    s1.add(4);
    s1.add(5);

    s1.show();

    cout<<"顺序表长度为:"<<s1.length()<<endl;

    //插入数据
    s1.insert_pos(1,1);
    s1.show();

    //删除数据
    s1.deiete_pos(1);
    s1.show();

    //访问数据
    cout<<"at="<<s1.at(2)<<endl;


    return 0;
}

结果:


http://www.kler.cn/a/282343.html

相关文章:

  • w039基于Web足球青训俱乐部管理后台系统开发
  • 开源共建 | 长安链开发常见问题及规避
  • 7.高可用集群架构Keepalived双主热备原理
  • mindspore发布件
  • 本地部署Apache Answer搭建高效的知识型社区并一键发布到公网流程
  • 【HAProxy09】企业级反向代理HAProxy高级功能之压缩功能与后端服务器健康性监测
  • 若依微服务Admin控制台不显示ruoyi-file问题解决
  • Mysql在服务器中的源码部署
  • Ps:渲染视频
  • 关于springboot对接chatglm3-6b大模型的尝试
  • 消息称华为纯血鸿蒙部分应用采用虚拟机方案
  • 三级_网络技术_53_应用题
  • pytorch Dataset类代码学习
  • 在PyCharm终端使用where命令不返回路径问题
  • 顶级域名服务器 - TLD服务器
  • RK方案有时一开机要设置GPIO口点平
  • Sentinel-1 Level 1数据处理的详细算法定义(九)
  • QT多线程遍历注册表
  • vray材质forC4D测试
  • Java相关工具/插件的安装教程汇总
  • SFF1604-ASEMI无人机专用SFF1604
  • HarmonyOS NEXT 实战开发:实现日常提醒应用
  • vue报错解决
  • python进阶篇-day01-面向对象基础
  • (154)时序收敛--->(04)时序收敛四
  • C语言关键字