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

结果:

相关推荐
一只专注api接口开发的技术猿几秒前
基于 Java 的淘宝 API 调用实践:商品详情页 JSON 数据结构解析与重构
大数据·数据结构·重构·json
君义_noip5 分钟前
信息学奥赛一本通 1508:Easy SSSP
c++·图论·信息学奥赛
末央&11 分钟前
【C++】深入浅出之继承
开发语言·c++
ChengZUOZZZ15 分钟前
蓝桥杯题目:二维前缀和
java·算法·蓝桥杯
可乐^奶茶1 小时前
2026《数据结构》考研复习笔记二(C++面向对象)
数据结构·c++·笔记
OSwich2 小时前
【虚幻C++笔记】接口
c++·笔记·虚幻
槐月杰4 小时前
C语言中冒泡排序和快速排序的区别
c语言·算法·排序算法
奋进的小暄5 小时前
数据结构(java)栈与队列
java·开发语言·数据结构
笺上山河梦6 小时前
文件操作(二进制文件)
开发语言·c++·学习·算法
大慕慕好懒7 小时前
PHP弱类型hash比较缺陷
算法·哈希算法