图书管理系统(C语⾔数据结构)
实验要求:
1、图书信息:包括ISBN、书名、主编、出版社、定价
2、功能:
(1)插⼊:若表中不存在新图书信息(ISBN不同),则插⼊(表尾)新图书信息。
(2)删除:按ISBN删除
(3)查:按ISBN查
(4)修改:按ISBN查,然后修改各个属性
(5)排序:按ISBN排序
(6)计数:输出图书信息的个数
(7)导⼊:从TXT⽂件中读取已有图书信息(不同的属性之间⽤tab键隔开)
(8)保存:将表中现有信息保存到txt⽂件中
(9)打印:在屏幕上显⽰所有图书信息
3、扩展功能(选做):
(1)增加按书名、主编、出版社进⾏查
(2)增加按书名、主编、出版社、定价排序
4、界⾯要求:简单的⼈机交互界⾯
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define OK 1
#define ERROR 0
#define OVERFLOW -1
#define LIST_INIT_SIZE 50
#define LISTINCREMENT 10
//宏定义,即定义常量
typedef int status;
typedef struct{
char ISBN[15];
char bookname[30];
char writername[10];
char publisher[20];
float price;
} ElemType;
typedef struct{
ElemType *elem;
int length;
int listsize;
} SqList;
//定义结构体类型,即 typedef 类型类型名
status InitList_Sq(SqList &L)
{//构造⼀个空的线性表L。
L.elem=(ElemType *)malloc(LIST_INIT_SIZE*sizeof(ElemType));
//申请初始化长度的内存
if(!L.elem){
/
/如果L的序列⾮空
exit(OVERFLOW);
//说明L被重定义了,抛出溢出
}
L.length=0;
//默认L内有0个元素
L.listsize=LIST_INIT_SIZE;
//默认L的容量为初始化长度
return OK;
}
int LocateElem_Sq(SqList L,char ISBN[])
{//在顺序表L中遍历查第1个值与e.ISBN相等的元素的位序,若到,返回其位序,否则返回0;for(int i=0;i<L.length;i++){
if(strcmp(ISBN,L.elem[i].ISBN)==0){
return i+1;
}
}
return0;
}
status ListInsert_Sq(SqList &L,ElemType e)
{//元素e插⼊表尾
ElemType *newbase;
if(LocateElem_Sq(L,e.ISBN)){
return ERROR;
}
if(L.length>=L.listsize){
newbase =(ElemType*)realloc(L.elem,(L.listsize+LISTINCREMENT)*sizeof(ElemType));
if(!newbase){
exit(OVERFLOW);
}
L.elem=newbase;
L.listsize+=LISTINCREMENT;
}
L.elem[L.length]=e;
return OK;
}
status ListDelete_Sq(SqList &L,char ISBN[],ElemType &e)
{//删除L中ISBN的元素,并返回删除元素;
int i,j;
if((i=LocateElem_Sq(L,ISBN))==0){
return ERROR;
}
e=L.elem[i-1];
for(j=i;j<L.length;j++){
L.elem[j-1]=L.elem[j];
}
L.length--;
return OK;
}
status SetElem_Sq(SqList &L,int i,ElemType e)
{//修改在i的位置的元素
if(i<1||i>L.length){
return ERROR;
}
L.elem[i-1]=e;
return OK;
}
void sort_ISBN(SqList &L)
{//对表中所有元素进⾏排序;
int i,j,k;
ElemType e;
for(i=0;i<L.length-1;i++){
k=i;
for(j=i+1;j<L.length;j++){
if(strcmp(L.elem[k].ISBN,L.elem[j].ISBN)>0){
k=j;
}
}
if(k!=i){
e=L.elem[i];
L.elem[i]=L.elem[k];
L.elem[k]=e;
}
}
}
void print(SqList L)
{//打印出所有元素
int i;
printf("\n图书信息为:\n");
for(i=0;i<L.length;i++){
printf("%-15s%-30s%-10s%-20s%-6.2f\n",L.elem[i].ISBN,L.elem[i].bookname,L.elem[i].writername,L.elem[i].publisher,L.elem[i].price); }
}
void import(SqList &L,char*filename)
c语言listinsert函数{//从⽂件中导⼊信息
FILE *fp;
int i;
char ISBN[15],bookname[30],writername[10],publisher[20];
float price;
if((fp=fopen(filename,"r"))==NULL){
printf("⽂件不存在!\n");
return;
while(!feof(fp)){
fscanf(fp,"%s%s%s%s%f",ISBN,bookname,writername,publisher,&price);
strcpy(L.elem[i].ISBN,ISBN);
strcpy(L.elem[i].bookname,bookname);
strcpy(L.elem[i].writername,writername);
strcpy(L.elem[i].publisher,publisher);
L.elem[i].price=price;
i++;
}
L.length=i;
fclose(fp);
}
void save(SqList L,char*filename)
{//把信息保存到⽂件
FILE *fp;
int i;
if((fp=fopen(filename,"w"))==NULL){
printf("⽂件不存在!\n");
return;
}
for(i=0;i<L.length;i++){
fprintf(fp,"%-15s\t%-30s\t%-10s\t%-20s\t%-6.2f\n",L.elem[i].ISBN,L.elem[i].bookname,L.elem[i].writername,L.elem[i].publisher,L.elem[i].price); }
fclose(fp);
}
int main(){
int ch;
SqList L;
char ISBN[15],filename[30];
int i;
ElemType e;
InitList_Sq(L);
printf("1. 插⼊ 2. 删除 3. 查 4. 修改元素 5. 按ISBN排序元素 6. 输出 7. 导⼊ 8. 保存 9. 退出\n");
printf("请选择:");
scanf("%d",&ch);
while(ch!=9){
switch(ch){
case1:printf("请输⼊要增加的元素");
scanf("%s%s%s%s%f",e.ISBN,e.bookname,e.writername,e.publisher,&e.price);
if(ListInsert_Sq(L,e)==OK){
printf("插⼊成功!当前信息为:\n");
print(L);
}
else{
printf("表中已存在该图书!\n");
}
break;
case2:printf("请输⼊删除的图书ISBN:");
scanf("%s",ISBN);
if(ListDelete_Sq(L,ISBN,e)==OK)
{
printf("删除成功!被删图书为%s\t%s\t%s\t%s\t%.2f\n",e.ISBN,e.bookname,e.writername,e.publisher,e.price);
print(L);
}
else
printf("该图书不存在!\n");
break;
case3:printf("请输⼊要查的图书ISBN:");
scanf("%s",&ISBN);
i=LocateElem_Sq(L,ISBN);
printf("该图书为%s\t%s\t%s\t%s\t%.2f\n",L.elem[i-1].ISBN,L.elem[i-1].bookname,L.elem[i-1].writername,L.elem[i-1].publisher,L.elem[i-1].price); }
else
printf("该图书不存在!\n");
break;
case4:printf("请输⼊要修改的图书ISBN:");
scanf("%s",&ISBN);
i=LocateElem_Sq(L,ISBN);
if(i==0){
printf("该图书不存在!\n");
}
else{
printf("请输⼊图书的ISBN,书名,主编,出版商和定价");
scanf("%s%s%s%s%f",e.ISBN,e.bookname,e.writername,e.publisher,e.price);
SetElem_Sq(L,i,e);
printf("修改成功,图书信息为:");
print(L);
}
break;
case5:sort_ISBN(L);
printf("按照ISBN排序后\n");
print(L);
break;
case6:print(L);
break;
case7:printf("请输⼊导⼊⽂件名:");
scanf("%s",filename);
import(L,filename);
break;
case8:printf("请输⼊导出⽂件名:");
scanf("%s",filename);
save(L,filename);
break;
default:printf("输⼊错误,请重新选择\n");
}
printf("1. 插⼊ 2. 删除 3. 查 4. 修改元素 5. 按ISBN排序元素 6. 输出 7. 导⼊ 8. 保存 9. 退出\n");
printf("请选择:");
scanf("%d",&ch);
}
}
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论