宝盈长盛体育
欢迎来到中博奥技术有限公司官网

nodejs图书管理系统

时间:2023-02-01 作者:老师 来源:网络 点击量:

nodejs图书管理系统

建议您尝试一下DoraCMS,Nodejs+express+mongodb编写的一套内容管理系统。DoraCMS开源没多久,但是已获得很多前端开发者的关注。目前市面上有很多内容管理系统(如织梦、帝国等),都是以php为基础编写的,而DoraCMS则是基于nodejs,只要有基本的前端开发经验和少量的js,就很容易上手。DoraCMS创建的目的是为了更深入的了解nodejs并付诸实践,开源的目的也是为了通过案例来不断改进我们的nodejs水平,共同提高;其次
DoraCMS结构清晰、模块简单,上手很容易。目前市面的cms结构复杂,想要自己修改定制学习成本比较高。初识nodejs的开发者可以了解一个
cms实现的基础过程,熟悉nodejs的也可以用DoraCMS 来进行二次开发,不用再从头开始。DoraCMS
遵循MIT协议完全开源,您可以自由定制属于你自己的网站而不必花很多时间去处理最基础的一些东西,为了让更多的人去了解和认识nodejs,于是
DoraCMS 诞生了。
DoraCMS是基于Nodejs+express+mongodb编写的一套内容管理系统,结构简单,较目前一些开源的cms,doracms易于拓展,特别适合前端开发工程师做二次开发。

宝盈长盛体育

图书管理系统【问题描述】设计一个计算机管理系统完成图书管理基本业务。【基本要求】1)每种书的登记内

宝盈长盛体育

一、对问题的描述和数据结构的选择

【问题描述】
设计一个计算机管理系统完成图书管理基本业务。
【任务要求】

1)每种书的登记内容包括书号、书名、著作者、现存量和库存量;
2)对书号建立索引表(线性表)以提高查找效率;
3)系统主要功能如下:
*采编入库:新购一种书,确定书号后,登记到图书帐目表中,如果表中已有,则只将库存量增加;
*借阅:如果一种书的现存量大于0,则借出一本,登记借阅者的书证号和归还期限,改变现存量;
*归还:注销对借阅者的登记,改变该书的现存量。

【进一步完成内容】

1)系统功能的进一步完善;
2)索引表采用树表。
3)设计内容
4)程序流程图
5)源程序
6)软件测试报告(包括所用到的数据及结果)

【数据结构】

这里我们简单的用单链表就可以实现。
// 图书管理系统
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <windows.h>
#include <conio.h>
#include <time.h>

/*定义图书有关的数据结构*/
struct book
{
int BookNum; /*图书编号*/
charBookName[20]; /*图书名字*/
char BookAuthor[15];/*图书作者*/
int nowCount; /*图书现存量*/
int allCount; /*图书库存量*/
};

/*定义与读者有关的数据结构*/
struct reader
{
int ReaderNum; /*读者编号*/
charReaderName[20]; /*读者的姓名*/
charReaderSex[8]; /*读者的性别*/
int ReaderAge; /*读者的年龄*/
charReaderTel[15]; /*读者的电话*/
int ReaderCount; /*读者目前已经借阅的数目*/
charpassword[16]; /*读者证件密码*/
chardate[10][100]; /*读者借阅日期*/
intReaderBorrow[10]; /*当前已经借阅的图书编号*/
charBorrowName[10][40];/*已经借阅的图书名字*/
};

/*定义与每条图书纪录有关的数据结构*/
typedef struct booknode
{
struct book data; /*数据域*/
struct booknode*next; /*指针域*/
}BookNode;

/*定义与每条读者纪录有关的数据结构*/
typedef struct readernode
{
struct readerdata; /*数据域*/
struct readernode*next; /*指针域*/
}ReaderNode;

/*定义图书馆中读者和藏书的总数目*/
struct rbnum
{
int rnum; /*读者总个数*/
int bnum; /*书籍总本数*/
}allRBnum;

/*******************************************/
/*函数声明*/
BookNode *OpenBook(); /*打开图书库文件*/
ReaderNode *OpenReader(); /*打开读者库文件*/
void InBook(BookNode *pbook); /*图书录入*/
void SaveBook(BookNode *pbook); /*图书信息保存*/
void SaveReader(ReaderNode *preader); /*读者信息保存*/
void BorrowBook(BookNode *pbook, ReaderNode *preader); /*图书借阅*/
void ReturnBook(BookNode *pbook, ReaderNode *preader); /*图书归还*/
void LookBook(BookNode *pbook); /*浏览图书库*/
void LookReader(ReaderNode *preader); /*浏览读者库*/
void InReader(ReaderNode *preader); /*借书证办理*/
void FindReaderAll(ReaderNode *preader); /*读者信息查询*/
ReaderNode *LoginReader(ReaderNode *preader); /*读者登陆验证*/
int LoginAdmin(); /*管理员登陆验证*/
void ModifyReader(ReaderNode *preader); /*修改读者信息*/
void ModifyBook(BookNode *pbook); /*修改图书信息*/
void GotoXY(int x, int y); /*光标定位*/
void erase(int n); /*擦除菜单选项*/
void menu(int n); /*菜单选项*/
void FindBook(BookNode *pbook); /*图书搜索*/
void LocalTime(char *strTime); /*获取系统本地时间*/
/*******************************************/

原文地址:

数据结构设计图书管理系统

#include <stdio.h> #include <string.h> #include <stdlib.h> // #define MAXSIZE 100 //最大值定义为100 #define LIST_INIT_SIZE 100//图书证使用者最大值定义为100 //借书人的结构体 typedef struct Boro//借书行为 { char BNum[20];//借书的书号 char RetDate[8];//归还日期 struct Boro *next; }Bor; typedef struct LinkBook { Bor *next; //该图书证的借书行为 char CNum[20]; //卡号 int Total; //借书的数量 }lend[LIST_INIT_SIZE];//借书人数组 //图书的结构体信息 typedef struct LNode { char CardNum[20];//图书证号 struct LNode *next; }LinkList; //借书人 typedef struct book {//每种图书需要登记的内容包括书号ISBN、书名、作者、出版社、总库存量和现库存量。 char num[20];//书号 char name[20];//书名 char auth[20];//作者 char pub[20];//出版社 int TotNum;//总库存 int NowNum;//现库存 LinkList *next;//借了该书的人 }ook[MAXSIZE]; // int Retotal;//读者数量 int total; //定义外部变量.书的种类数 // //结构体初始化 void InitBo(ook &boo) //初始化图书信息 { for(int i=0;i<MAXSIZE;i++) { boo[i].NowNum=0; boo[i].TotNum=0; boo[i].next=NULL; } } void InitRe(lend &Lin) //初始化借阅者信息 { for(int i=0;i<LIST_INIT_SIZE;i++) Lin[i].next=NULL; } // int mid=0;//外部函数mid,用来返回查找到的位置 bool BinarySearch(ook boo,char SearchNum[]) //二分法查找比较书号 { //用bool函数,但由于函数不能有两个返回值,所以设置一个外部变量mid,用来返回查找到的位置 int low=0,high=total-1; int found=0; while(low<=high) { mid=(low+high)/2; //中间点 if(strcmp(boo[mid].num,SearchNum)==0) //书号相同 { found=1; return true; }//查找成功 if(strcmp(boo[mid].num,SearchNum)!=0)//书号不同 high=mid-1; else low=mid+1; } if(found==0) return false; //查找失败 } void Buy(ook &boo, char BuyNum[]) {//1、 采编入库:新购入一种书,如果该书在图书账目中已经存在,则将其库存量增加(包 //括总库存量和现库存量),如果该书不存在,则在图书账目中增加一种书,总库存量和现库存量均为1。 if(BinarySearch(boo,BuyNum)) //如果书库中有此书 { boo[mid].TotNum++; //总库存加1 boo[mid].NowNum++; //现库存加1 printf("入库成功.\n"); printf("已更改书库中该书的信息。编号 %s 的书 %s 作者是 %s ,出版社是 %s ,目前的总库存是 %d ,现库存是 %d 。\n",boo[mid].num,boo[mid].name,boo[mid].auth,boo[mid].pub,boo[mid].TotNum,boo[mid].NowNum); } if(!BinarySearch(boo,BuyNum)) { int i; for(i=total;i>mid&&total;i--) //插在适合位置 保持有序 boo[i]=boo[i-1]; //空出插入位置 printf("该书在书库中不存在。设立新书目,请补全书的详细信息。\n"); strcpy(boo[i].num,BuyNum); printf("该书购入的数量是:"); scanf(" %d",&boo[i].NowNum); boo[i].TotNum=boo[i].NowNum; printf("该书的名字是:"); scanf(" %s",&boo[i].name); printf("该书的作者是:"); scanf(" %s",&boo[i].auth); printf("该书的出版社是:"); scanf(" %s",&boo[i].pub);//补全信息 boo[i].next=NULL; total++;//总量+1 printf("已增加该书的信息。编号 %s 的书 %s 作者是 %s ,出版社是 %s ,目前的总库存是 %d ,现库存是 %d 。\n",boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum); printf("入库成功.\n"); } } void Delete(ook &boo,char DeleteNum[]) {//2、 清空库存:某一种书已无保留价值,将它从图书账目中注销。 if(BinarySearch(boo,DeleteNum)==false||total==0) //如果无此书 printf("书库中没有该书.\n"); if(BinarySearch(boo,DeleteNum))//若有 { if(!boo[mid].next) { int j; for( j=mid;j<total;j++) boo[j]=boo[j+1]; strcpy(boo[j].num,boo[j+1].num); strcpy(boo[j].name,boo[j+1].name); strcpy(boo[j].auth,boo[j+1].auth); strcpy(boo[j].pub,boo[j+1].pub); boo[j].TotNum=boo[j+1].TotNum; boo[j].NowNum=boo[j+1].NowNum; printf("已成功删除该书.\n"); } else printf("该书有借阅者,无法删除。\n"); } } void Borrow(ook &boo,lend &Lin,char BorrowNum[],char CaNum[]) {//3、 借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1, //并登记借阅者的图书证号和归还期限。 Bor *p,*q; LinkList *m,*n; if(!BinarySearch(boo,BorrowNum)||total==0) //如果没有找到此书 printf("书库里没这书。\n");//如果有这书 if(BinarySearch(boo,BorrowNum)) //书库里有 { if(boo[mid].NowNum>0) //看现库存是否大于0 { boo[mid].NowNum--;//借出一本,少1 if(boo[mid].next==NULL) //若该书信息下显示该种书还没被人借过 { m=(LinkList *)malloc(sizeof(LNode));//分配 boo[mid].next=m;//该图书信息中的链表的第一个结点 strcpy(m->CardNum,CaNum); m->next=NULL;//后一个结点为空 } else //如果已经有人在借这书了 { m=boo[mid].next; while(m->next) //遍历到最后一个结点 m=m->next; n=(LinkList *)malloc(sizeof(LNode));//分配空间,增加1个结点 m->next=n; strcpy(n->CardNum,CaNum);//记录证号 n->next=NULL; } int i=0; for(i=0;i<Retotal;i++)// { if(!strcmp(Lin[i].CNum,CaNum))//如果已经有该图书证的信息 { p=Lin[i].next; while(p->next)p=p->next;//遍历到最后一个结点 q=(Bor *)malloc(sizeof(Boro));//分配空间 p->next=q; strcpy(q->BNum,BorrowNum); //记录书号 printf("输入归还日期:"); scanf("%s",&q->RetDate); q->next=NULL; printf("借阅成功.\n"); break; //找到证了就跳出循环 } } if(i==Retotal)//如果没有这张证的信息 { strcpy(Lin[i].CNum,CaNum); //记录证号 p=(Bor *)malloc(sizeof(Boro)); //分配空间 Lin[i].next=p; strcpy(p->BNum,BorrowNum); printf("输入归还日期:"); scanf(" %s",&p->RetDate); p->next=NULL; Retotal++; //借阅证号信息总数加1 printf("借阅成功.\n"); } } else printf("借阅失败.该书现在库存为0.\n"); } } void Return(ook &boo,lend &Lin,char ReturnNum[],char BorrowerNum[]) {//4、 归还:注销对借阅者的登记,改变该书的现存量。 Bor *p,*q; LinkList *m,*n; int flag=0;//设置一个参数 if(!BinarySearch(boo,ReturnNum)||!total) //没书 printf("书库中无此书.\n"); if(BinarySearch(boo,ReturnNum)) //有书 { m=boo[mid].next; if(!strcmp(m->CardNum,BorrowerNum)) //如果是第一个借的人还的 { boo[mid].NowNum++; //现库存加1 boo[mid].next=m->next; //删除结点 free(m); //释放该结点的空间空间 } else { while(m->next) //查找归还者的借阅者结点 { if(!strcmp(m->next->CardNum,BorrowerNum)) //如果找到 { n=m->next; //n为归还者的借阅结点 m->next=n->next; //m指向归还者的借阅结点的下一结点 free(n); //释放空间 boo[mid].NowNum++; //现库存加1 break; } m=m->next; } } } //在借阅者表里查找借阅者信息 for(int i=0;i<Retotal;i++) { if(!strcmp(Lin[i].CNum,BorrowerNum)) //如果找到借阅者 { p=Lin[i].next; if(!strcmp(p->BNum,ReturnNum)) //如果是归还的是借的第一本书 { Lin[i].next=p->next; //指向下一借书结点 free(p); //释放结点空间 printf("成功归还该书.\n"); flag=1; break; } else //找不到 { while(p->next) //找到归还书的借书结点 { if(!strcmp(p->next->BNum,ReturnNum)) //如果找到 { q=p->next; //q为归还书的借书结点 p->next=q->next; //p指向下一借书结点 free(q); //释放空间 printf("成功归还该书.\n"); flag=1; break; } p=p->next; } } } } for(int k=0;k<Retotal;k++) if(!Lin[k].next) { int j; for(j=k;j<Retotal;j++) Lin[j]=Lin[j+1]; //其后都往前移一位,覆盖掉当前信息 strcpy(Lin[j].CNum," "); //删除图书证号 Retotal--; //图书证数减1 } //删除当前状态下没借书的图书证的信息,节省空间 if(flag==0) printf("无该证信息.\n"); } //5、 查找:实现按三种查询条件之一查找:按书号查找、 //按书名查找、按作者查找。注:可不实现组合查找,即几个条件组合查找。 void SearchByNum(ook &boo,char SeaNum[]) {//BY NUM 根据书号查找 LinkList *p; p=boo[mid].next; if(BinarySearch(boo,SeaNum)==false)printf("对不起,未找到您想查找的书。\n");//二分查找 没找到 else//找到了的话 { { printf("┏━━━━━━━┳━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━┳━━━━━┓\n"); printf("┃ 书号 ┃ 书名 ┃ 作者 ┃ 出版社 ┃ 现库存 ┃ 总库存 ┃\n"); printf("┣━━━━━━━╋━━━━━━━╋━━━━━━━━╋━━━━━━━━╋━━━━━╋━━━━━┫\n"); printf("┃%14s┃%14s┃%16s┃%16s┃%10d┃%10d┃\n",boo[mid].num,boo[mid].name,boo[mid].auth,boo[mid].pub,boo[mid].NowNum,boo[mid].TotNum); printf("┗━━━━━━━┻━━━━━━━┻━━━━━━━━┻━━━━━━━━┻━━━━━┻━━━━━┛\n"); if(boo[mid].next!=NULL) { printf("┏━━━━━━━┓\n"); printf("┃ 已借该书的 ┃\n"); printf("┃ 图书证号 ┃\n"); while(p) { printf("┣━━━━━━━┫\n"); printf("┃%14s┃\n",p->CardNum); p=p->next; } printf("┗━━━━━━━┛\n"); } } while(p) { printf(" %s ",p->CardNum);//在按书号查找的函数里也显示借了这本书的借阅者的证号 p=p->next; } printf(" \n"); }//显示查找的书籍的信息 } void SearchByName(ook &boo) {//BY NAME 根据书名查找 char SeaName[20]; printf("输入想查找的书的书名:\n"); scanf(" %s",&SeaName); printf("找到符合该书名的书的详细信息如下:\n"); for(int i=0;i<total;i++) { if(strcmp(SeaName,boo[i].name)==0)//如果书名一样 { printf("书号:%s\n书名:%s\n作者:%s\n出版社:%s\n总库存量:%d\n现库存量:%d\n\n",boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum); }//显示符合信息的所有书籍的信息 } } void SearchByAuth(ook &boo) {// BY AUTH 根据作者查找 char SeaAuth[20]; printf("输入想查找的书的作者:\n"); scanf(" %s",&SeaAuth); printf("找到符合该作者的书的详细信息如下:\n"); for(int i=0;i<total;i++) { if(strcmp(SeaAuth,boo[i].auth)==0)//如果作者一样 { printf("书号:%s\n书名:%s\n作者:%s\n出版社:%s\n总库存量:%d\n现库存量:%d\n\n",boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum); }//显示符合信息的所有书籍的信息 } } //6、 查看:可查看某图书证号的借阅者借阅的全部图书,可查看全部超期未还的图书。 void ViewCard(ook &boo,lend &Lin) {//查看某图书证号的借阅者借阅的全部图书 char Num[20]; printf("请输入您所想要查看的图书证号:\n"); scanf(" %s",&Num); Bor *p; int qqq=0; for(int i=0;i<Retotal;i++) { if(strcmp(Lin[i].CNum,Num)==0) //找到该证 { printf("这个证借的书有:\n"); p=Lin[i].next; while(p) { printf(" %s ",p->BNum); //书号 p=p->next; } printf("\n"); qqq=1; break; } } if(qqq==0) printf("该证不存在.\n"); } void ViewBook(ook &boo,lend &Lin) {//查看全部超期未还的图书 char date[8]; Bor *p; printf("请输入日期(请按格式20060605输入):\n"); scanf(" %s",&date); printf("所有超期未还的书有:\n"); for(int i=0;i<Retotal;i++) { p=Lin[i].next; while(p)//当p不空时 { if(strcmp(p->RetDate,date)<0) //超过日期 { printf("书号为 %s 证号为 %s 应归还日期为 %s \n",p->BNum,Lin[i].CNum,p->RetDate); }//显示所有超期未还的书的信息 p=p->next; } } } void Menu() //菜单 { printf("┏—————————————————M E N U————————————————┓\n"); printf("│ │\n"); printf("│ 1. 采编入库:新购入一种书,如果该书在图书账目中已经存在, │\n"); printf("│ 则将其库存量增加(包括总库存量和现库存量)。 │\n"); printf("│ 如果该书不存在,则在图书账目中增加一种书, │\n"); printf("│ 总库存量和现库存量均为输入的数字。 │\n"); printf("│ 2. 清空库存:某一种书已无保留价值,将它从图书账目中注销。 │\n"); printf("│ 3. 借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1, │\n"); printf("│ 并登记借阅者的图书证号和归还期限。 │\n"); printf("│ 4. 归还:注销对借阅者的登记,改变该书的现存量。 │\n"); printf("│ 5. 按书号查找。 │\n"); printf("│ 6. 按书名查找。 │\n"); printf("│ 7. 按作者查找。 │\n"); printf("│ 8. 查看某图书证号的借阅者借阅的全部图书。 │\n"); printf("│ 9. 查看全部超期未还的图书。 │\n"); printf("│ 0. 退出图书管理系统。 │\n"); printf("│ │\n"); printf("┗—————————————请 选 择 你 需 要 的 操 作————————————┛\n"); } void main() { ook Bo; lend Lin; char BNum[20]; char CNum[20]; printf("-----------------------欢 迎 进 入 图 书 管 理 系 统!---------------------------\n\n"); int choice=10; int SearchCho=10,ViewCho=10; while(choice!=0) { Menu();//显示菜单 scanf(" %d",&choice); switch(choice) { case 1://采编入库 printf("请输入入库的书的书号:"); scanf(" %s",BNum); Buy(Bo,BNum); break; case 2://清空库存 printf("请输入想要清除的书的书号:"); scanf(" %s",BNum); Delete(Bo,BNum); break; case 3://借阅 printf("请输入想要借阅的书的书号:\n"); scanf(" %s",&BNum); printf("请输入图书证号:"); scanf(" %s",&CNum); Borrow(Bo,Lin,BNum,CNum); break; case 4://归还 printf("请输入想要归还的书的书号:\n"); scanf(" %s",&BNum); printf("请输入图书证号:"); scanf(" %s",&CNum); Return(Bo,Lin,BNum,CNum); break; case 5://查找//根据书号查找 printf("请输入书号:");//输入书号查找 scanf(" %s",&BNum); SearchByNum(Bo,BNum); break; case 6://根据书名查找 SearchByName(Bo); break; case 7://根据作者查找 SearchByAuth(Bo); break; case 8://查看某图书证所借的所有书 ViewCard(Bo,Lin); break; case 9: //查看全部超期未还的书 ViewBook(Bo,Lin); break; case 0://退出系统 exit(0);break; default:printf("输入错误!\n");exit(0);break; } } }

图书馆管理系统设计,包括代码设计,输出输入设计论文

我在我的电脑运行通过,这个程序是我们的一个作业,可能是你机子的问题
#include<iostream>
using namespace std;
struct book{
int number;
char name[20];
char addr[30];
char writer[12];
double price;
struct book *next;
};

typedef struct book node;
typedef node *link;

void printstart(){
cout<<"------------------------------------\n";
}

void Wrong(){
cout<<"\n=====>提示:输入错误!\n";
}

void Nofind(){
cout<<"\n=====>提示:没有找到相应书籍!\n";
}

void printc(){
cout<<" 编号\t书名\t出版社\t作者\t价格\n";
}

link inserte_link1(link head){
int number;
char *na=new char[12];
char *ad=new char[30];
char *writer=new char[12];
double price;
link pPre,p2,pBac;
cout<<"请输入";
printc();
cin>>number>>na>>ad>>writer>>price;
p2=new node;
p2->number=number;
strcpy(p2->name,na);
strcpy(p2->addr,ad);
strcpy(p2->writer,writer);
p2->price=price;
p2->next=NULL;
delete na;
if(p2->number>head->number){
p2->next=head;
head=p2;
return head;
}
else{
pPre=head;
pBac=pPre->next;
while(1){
if(p2->number>pBac->number&&p2->number<pPre->number){
p2->next=pBac;
pPre->next=p2;
return head;
}
else{
pPre=pBac;
pBac=pBac->next;
}
}
}
}

link create_link(link head){
head=new node;
head->number=-1;
head->next=NULL;
int m,i;
cout<<"请输入本次所创建的图书数:\n";
cin>>m;
for(i=0;i<m;i++)
head=inserte_link1(head);
return head;
}
int print_link(link head){
link p1;
p1=head;
if(p1->next==NULL){
printstart();
cout<<"此成绩表为空!\n";
printstart();
return 0;
}
printc();
while(p1->next){
cout<<p1->number<<'\t'<<p1->name<<'\t'<<p1->addr<<'\t'<<p1->writer<<'\t'<<p1->price<<endl;
p1=p1->next;
}
printstart();
return 0;
}
void menu(){
printf("\n\n\n");
printf("\t1载入书籍信息\t\t\t\t2删除书籍信息\n\n");
printf("\t3全显书籍信息\t\t\t\t4修改书籍信息\n\n");
printf("\t0退出系统\n\n");
printf("%*****************************************%");
printf("\n");
}
link delete_link(link head){
if(head==NULL){
cout<<"///////////////////////////\n";
cout<<"此成绩表为空!\n";
cout<<"///////////////////////////\n";
return NULL;
}
link p1,p2;
int num;
cout<<"请输入所要删除书籍的号码:\n";
cin>>num;
while(head!=NULL&&head->number==num){//所删除的在链头
p2=head;
head=head->next;
delete p2;
cout<<"已删除!\n";
}
p1=head;
p2=head->next;
while(p2!=NULL){
if(p2->number==num){
p1->next=p2->next;
delete p2;
cout<<"已删除!\n";
return head;
}
else
p1=p2;
p2=p1->next;
}
Nofind();
return head;
}
link modify_link(link head){
int num,number;
char *na=new char[20];
char *ad=new char[30];
char *writer=new char[12];
double price;
link p1;
p1=head;
cout<<"请输入要修改书籍的号码:\n";
cin>>num;
while(p1->next!=NULL){
if(p1->number==num){
cout<<"此书籍的信息为:\n";
printc();
cout<<p1->number<<'\t'<<p1->name<<'\t'<<p1->addr<<'\t'<<p1->writer<<'\t'<<p1->price<<endl;
cout<<"请输入";
printc();
cin>>number>>na>>ad>>writer>>price;
p1->number=number;
strcpy(p1->name,na);
strcpy(p1->addr,ad);
strcpy(p1->writer,writer);
p1->price=price;
cout<<"修改成功!\n";
return head;
}
p1=p1->next;
}
Nofind();
return head;
}
void main(){
int t;
link head=NULL;
int choice;
do{
menu();
cout<<"请输入操作的序号!\n";
cin>>choice;
switch(choice){
case 1:
head=create_link(head);
break;
case 2:
head=delete_link(head);
break;
case 3:
t=print_link(head);
break;
case 4:
head=modify_link(head);
break;
case 0:
cout<<"谢谢使用!\n";
exit(0);
default:
Wrong();
break;
}
}while(1);
}

标签

本文网址:/cgal/9015.html

相关资讯

我是中博奥客服:小奥
中博奥技术有限公司& 版权所有工信部备案号:豫ICP备11015869号-8 Copyright © 2023-2024

档案整理档案数字化

档案扫描档案管理软件系统

TEL:18937133779

To Top