通过线性表的顺序存储--实现图书信息管理(数据结构---c++)
本文中的代码实现需用的为:C++
文章目录
实验目的
- 掌握线性表的顺序存储和链式存储
- 掌握殊勋表和链表的基本操作
- 明确线性表两种不同存储结构的特点
实验步骤
- 顺序表的初始化:为书序表L动态分配一个预定义大小的数组空间,使elem指向这段空间的基地址,将表长设置为0。
- 顺序表的取值:判断指定位置序号
i值是否合理(1=,若不合理,则返回ERROR。若i合理,则将第i个数据元素L.length[i-1]付给参数e,通过e返回i个数据元素的值。 - 顺序表的插入:判断插入位置
i是都合法,若不合法返回ERROR。判断顺序表的存储空间是否已满,若满返回ERROR。将第n个至第i个元素依次向后移动一个位置。空出第i个位置,将要插入的元素e,放入第i个位置表长加一。
实验内容
1:初始化
//顺序表的初始化
Status InitList_Sq(SqList &L){//够造一个空的顺序表LL.elem = new Book[MAXSIZE];//为顺序表分配一个大小为MAXSIZE的数组空间if(!L.elem)exit(OVERFIOW);L.length = 0;return OK;
}
2:取值
//顺序表取值
Staus GetElem(SqList L,int i,Book &e){if(i<1||i>L.length)return ERROR;//判断I值是否合理,若不合理,返回ERRORe = L.elem[i-1];//elem[i-1]单元存储第i个数据元素return OK;
}
3:插入
//顺序表的插入
Status ListInsert_Sq(SqList L,int i,Book e){//在顺序表L中第I个位置之前插入新的元素e//i值得合法范围是1<=i<=L.lenth+1if((i<1)||(i>L.length+1))return ERROR;//i值不合法if(L.length == MAXSIZE)return ERROR;//当前存储空间已满for(int j=L.length-1;j>=i-1;j--)L.ele[j+1] = L.elem[j];//插入位置及之后的元素后移L.ele[i-1] = e;//将新元素e放入第i个位置++L.length;//表增长1return OK;
}
实验所需数据
ISBN 书名 定价
9787302257646 程序设计基础 25
9787302219972 单片机技术及应用 32
9787302203513 编译原理 46
9787811234923 汇编语言程序设计教程 21
9787512100831 计算机操作系统 17
9787302265436 计算机导论实验指导 18
9787302180630 实用数据结构 29
9787302225065 数据结构(C语言版) 38
9787302171676 C#面向对象程序设计 39
9787302250692 C语言程序设计 42
9787302150664 数据库原理 35
9787302260806 Java编程与实践 56
9787302252887 Java程序设计与应用教程 39
9787302198505 嵌入式操作系统及编程 25
9787302169666 软件测试 24
9787811231557 Eclipse基础与应用 35
将数据保存到一个名字为 book的txt文件中,并将这个文件放到源码同目录下。
程序源码
#include
#include
#include
#include
using namespace std;
#define OK 1
#define ERROR 0
#define OVERFLOW -2
typedef int Status; //Status 是函数返回值类型,其值是函数结果状态代码。
typedef int ElemType; //ElemType 为可定义的数据类型,此设为int类型#define MAXSIZE 100 //顺序表可能达到的最大长度
struct Book {string id;//ISBNstring name;//书名double price;//定价
};
typedef struct {Book *elem; //存储空间的基地址int length; //当前长度
} SqList;Status InitList_Sq(SqList &L) { //算法2.1 顺序表的初始化//构造一个空的顺序表LL.elem = new Book[MAXSIZE]; //为顺序表分配一个大小为MAXSIZE的数组空间if (!L.elem)exit(OVERFLOW); //存储分配失败退出L.length = 0; //空表长度为0return OK;
}Status GetElem(SqList L, int i, Book &e) {//算法2.2 顺序表的取值if (i < 1 || i > L.length)return ERROR; //判断i值是否合理,若不合理,返回ERRORe = L.elem[i - 1]; //elem[i-1]单元存储第i个数据元素return OK;
}int LocateElem_Sq(SqList L, double e) { //算法2.3 顺序表的查找//顺序表的查找for (int i = 0; i < L.length; i++)if (L.elem[i].price == e)return i + 1;//查找成功,返回序号i+1return 0;//查找失败,返回0
}Status ListInsert_Sq(SqList &L, int i, Book e) { //算法2.4 顺序表的插入//在顺序表L中第i个位置之前插入新的元素e//i值的合法范围是1<=i<=L.length+1if ((i < 1) || (i > L.length + 1))return ERROR; //i值不合法if (L.length == MAXSIZE)return ERROR; //当前存储空间已满for (int j = L.length - 1; j >= i - 1; j--)L.elem[j + 1] = L.elem[j]; //插入位置及之后的元素后移L.elem[i - 1] = e; //将新元素e放入第i个位置++L.length; //表长增1return OK;
}Status ListDelete_Sq(SqList &L, int i) { //算法2.5 顺序表的删除//在顺序表L中删除第i个元素,并用e返回其值//i值的合法范围是1<=i<=L.lengthif ((i < 1) || (i > L.length))return ERROR; //i值不合法for (int j = i; j <= L.length; j++)L.elem[j - 1] = L.elem[j]; //被删除元素之后的元素前移--L.length; //表长减1return OK;
}int main() {SqList L;int i = 0, temp, a, c, choose;double price;Book e;string head_1, head_2, head_3;cout << "1. 建立\n";cout << "2. 输入\n";cout << "3. 取值\n";cout << "4. 查找\n";cout << "5. 插入\n";cout << "6. 删除\n";cout << "7. 输出\n";cout << "0. 退出\n\n";choose = -1;while (choose != 0) {cout << "请选择:";cin >> choose;switch (choose) {case 1://创建顺序表if (InitList_Sq(L))cout << "成功建立顺序表\n\n";elsecout << "顺序表建立失败\n\n";break;case 2: {//顺序表信息输入i = 0;L.elem = new Book[MAXSIZE];if (!L.elem)exit(OVERFLOW);L.length = 0;fstream file;file.open("book.txt");if (!file) {cout << "错误!未找到文件!" << endl;exit(ERROR);}file >> head_1 >> head_2 >> head_3;while (!file.eof()) {file >> L.elem[i].id >> L.elem[i].name >> L.elem[i].price;i++;}cout << "输入 book.txt 信息完毕\n\n";L.length = i;file.close();}break;case 3://顺序表的取值cout << "请输入一个位置用来取值:\n";cin >> i;temp = GetElem(L, i, e);if (temp != 0) {cout << "查找成功\n";cout << "第" << i << "本图书的信息是:\n";cout << left << setw(15) << e.id << "\t" << left << setw(50)<< e.name << "\t" << left << setw(5) << e.price << endl<< endl;} elsecout << "查找失败!位置超出范围\n\n";break;case 4: //顺序表的查找cout << "请输入所要查找价格:";cin >> price;temp = LocateElem_Sq(L, price);if (temp != 0) {cout << "查找成功\n";cout << "该价格对应的书名为:" << L.elem[temp - 1].name << endl << endl;} elsecout << "查找失败!没有这个价格对应的书籍\n\n";break;case 5: //顺序表的插入cout << "请输入插入的位置和书本信息,包括:编号 书名 价格(用空格隔开):";cin >> a;cin >> e.id >> e.name >> e.price; //输入a和b,a代表插入的位置,b代表插入的数值(书本信息)if (ListInsert_Sq(L, a, e))cout << "插入成功.\n\n";elsecout << "插入失败.\n\n";break;case 6: //顺序表的删除cout << "请输入所要删除的书籍的位置:";cin >> c;if (ListDelete_Sq(L, c))cout << "删除成功.\n\n";elsecout << "删除失败.\n\n";break;case 7: //顺序表的输出cout << "当前图书系统信息(顺序表)读出:\n";for (i = 0; i < L.length; i++)cout << left << setw(15) << L.elem[i].id << "\t" << left<< setw(50) << L.elem[i].name << "\t" << left<< setw(5) << L.elem[i].price << endl;cout << endl;break;}}return 0;
}
END!

希望这篇文章能对你有帮助,那就,拜了个拜啦!
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
