【ID:17】【20分】A. DS顺序表--类实现
创始人
2024-05-28 17:34:29
0

时间限制1秒内存限制128兆字节

题目描述

用C++语言和类实现顺序表

属性包括:数组、实际长度、最大长度(设定为1000)

操作包括:创建、插入、删除、查找

类定义参考

输入

第1行先输入n表示有n个数据,即n是实际长度;接着输入n个数据 第2行输入要插入的位置和新数据 第3行输入要插入的位置和新数据 第4行输入要删除的位置 第5行输入要删除的位置

第6行输入要查找的位置

第7行输入要查找的位置

输出

数据之间用空格隔开

第1行输出创建后的顺序表内容,包括顺序表实际长度和数据

每成功执行一次操作(插入或删除),输出执行后的顺序表内容

每成功执行一次查找,输出查找到的数据

如果执行操作失败(包括插入、删除、查找等失败),输出字符串error,不必输出顺序表内容

样例查看模式

正常显示查看格式

输入样例1<-复制

输出样例1

提示

第i个位置是逻辑意义的位置,从1开始,在实际编程用数组,从0开始,对应数组i-1位置

#include
using namespace std;
#define ok 0
#define error -1class SeqList
{
private:int* list;int maxsize;int size;
public :SeqList();SeqList(int *l,int s);~SeqList();int list_size();int list_inser(int i, int item);int list_del(int i);int list_get(int i);void list_display();void push(int item);
};
SeqList::SeqList()
{maxsize = 1000;size = 0;list = new int[maxsize];//直接创建的数组的最长长度为max
}
SeqList::SeqList(int* l, int s)
{list = new int[s];for (int i = 0; i < s; i++){list[i] = l[i];}size = s;
}
SeqList::~SeqList()
{delete[]list;
}
//第i个位置是逻辑意义的位置,从1开始,在实际编程用数组,从0开始,对应数组i-1位置
int SeqList::list_inser(int i, int item)
{//数组多一个//插到i位置上//从后往前开始往后排if (i > size+1 || i <= 0 || size == maxsize){return error;}else{for (int j = size; j >= i; j--){list[j] = list[j - 1];}list[i - 1] = item;//要插入的项size += 1;return ok;}
}
int SeqList::list_size()
{return size;
}
int SeqList::list_del(int i)
{if (i > size || i <= 0){return error;}else{//从前往后for (int j = i - 1; j < size; j++){list[j] = list[j + 1];}size -= 1;return ok;}
}
int SeqList::list_get(int i)
{if (i > size || i <= 0){return error;}else{return list[i-1];}
}
void SeqList::list_display()
{cout << size << " ";for (int i = 0; i < size; i++){cout << list[i] << " ";}cout << endl;
}
void SeqList::push(int item)
{list[size] = item;size++;
}
int main()
{int size;cin >> size;int* list = new int[size];for (int i = 0; i < size; i++){cin >> list[i];}SeqList s;//由于有参与无参只能出现一个,而且题目很明显是要调用无参构造,所以只能在构建一个成员方法for (int i = 0; i < size; i++){s.push(list[i]);}s.list_display();int index, number;cin >> index >> number;if (s.list_inser(index, number)==ok){s.list_display();}else{cout << "error" << endl;}cin >> index >> number;if (s.list_inser(index, number) == ok){s.list_display();}else{cout << "error" << endl;}cin >> index;if (s.list_del(index) == ok){s.list_display();}else{cout << "error" << endl;}cin >> index;if (s.list_del(index)==ok){s.list_display();}else{cout << "error" << endl;}cin >> index;if (s.list_del(index) == ok){s.list_display();}else{cout << "error" << endl;}cin >> index;if (index > s.list_size() + 1 || index <= 0){cout << "error" << endl;}{cout << s.list_get(index) << endl;}return 0;
}

相关内容

热门资讯

元宵节的作文600字 【精品】元宵节的作文600字8篇  在日常生活或是工作学习中,大家都写过作文吧,写作文是培养人们的观...
植树节的作文500字 【精华】植树节的作文500字四篇  在平平淡淡的日常中,大家都经常接触到作文吧,写作文是培养人们的观...
帮奶奶捶背作文 帮奶奶捶背作文帮奶奶捶背今天是五一国际劳动节,我们全家都放假。我一起床,来到客厅,就看见奶奶已经把菜...
我的暑假打算作文 我的暑假打算作文  在平平淡淡的学习、工作、生活中,大家都有写作文的经历,对作文很是熟悉吧,通过作文...
关于秋季校运会学生作文   导语:仰望国旗在天空飘扬,左顾山间一片秋色,金色的十一月,收获的季节;我们收获什么?我校首届运动...
母亲的爱作文 母亲的爱作文母亲的爱  20 卢颖舜  母亲的爱是无私的,也是伟大的,我们因该好好珍惜这份爱。  还...
六年级下册家乡的风俗作文60... 六年级下册家乡的风俗作文600字(精选63篇)  在平平淡淡的学习、工作、生活中,大家或多或少都会接...
春节的作文100字 【推荐】春节的作文100字三篇  无论是身处学校还是步入社会,大家都有写作文的经历,对作文很是熟悉吧...
3年级上册语文作文 3年级上册语文作文3年级上册语文作文1. 春节的起源春节和年的概念,最初的含意来自农业,古时人们把谷...
寒假记事作文600字 寒假记事作文600字似乎从小到大写涉及亲情的作文,描写对象大都是母亲,写她们的温柔、善良与慈爱。我们...
写圣诞节的作文 写圣诞节的作文(通用27篇)  在平凡的学习、工作、生活中,大家都不可避免地要接触到作文吧,借助作文...
寒假的作文 寒假的作文9篇  无论在学习、工作或是生活中,大家最不陌生的就是作文了吧,借助作文人们可以实现文化交...
快乐圣诞节作文 快乐圣诞节作文(精选15篇)  在我们平凡的日常里,大家一定都接触过作文吧,写作文可以锻炼我们的独处...
六一儿童节的作文400字 【精选】六一儿童节的作文400字锦集8篇  在平凡的学习、工作、生活中,大家都接触过作文吧,写作文是...
以春节为话题的作文600字 【精品】以春节为话题的作文600字4篇  在学习、工作乃至生活中,大家都经常看到作文的身影吧,作文要...
端午节看图写话作文 端午节看图写话作文  导语:每年农历五月初五为端午节,是中国民间的传统节日。下面是小编整理的端午节看...
又是一年清明节作文 2020年又是一年清明节作文(通用10篇)  无论在学习、工作或是生活中,大家都接触过作文吧,借助作...
教师节的作文700字 教师节的作文700字四篇  在平平淡淡的学习、工作、生活中,大家都经常接触到作文吧,根据写作命题的特...
欢乐圣诞节优秀作文 欢乐圣诞节优秀作文(精选12篇)  在日常学习、工作抑或是生活中,许多人都写过作文吧,作文是从内部言...
国庆游记作文 国庆游记作文9篇  在日常生活或是工作学习中,大家一定都接触过作文吧,借助作文可以宣泄心中的情感,调...