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;
}

结果:

相关推荐
醉城夜风~25 分钟前
[数据结构]双链表详解
数据结构
曼巴UE526 分钟前
UE5.3 C++ TArray系列(一)
开发语言·c++·ue5
菜鸟一枚在这1 小时前
深度解析建造者模式:复杂对象构建的优雅之道
java·开发语言·算法
gyeolhada1 小时前
2025蓝桥杯JAVA编程题练习Day5
java·数据结构·算法·蓝桥杯
阿巴~阿巴~1 小时前
多源 BFS 算法详解:从原理到实现,高效解决多源最短路问题
开发语言·数据结构·c++·算法·宽度优先
给bug两拳1 小时前
Day9 25/2/22 SAT
算法
CoderCodingNo2 小时前
【GESP】C++二级真题 luogu-b3924, [GESP202312 二级] 小杨的H字矩阵
java·c++·矩阵
_Itachi__2 小时前
LeetCode 热题 100 73. 矩阵置零
算法·leetcode·矩阵
夏末秋也凉2 小时前
力扣-贪心-376 摆动序列
算法·leetcode