《最新VC--综合实验-图书馆管理系统.doc》由会员分享,可在线阅读,更多相关《最新VC--综合实验-图书馆管理系统.doc(80页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-dateVC-综合实验-图书馆管理系统VC+综合实验 图书馆管理系统VC+综合实验 图书馆管理系统.txt都是一个山的狐狸,你跟我讲什么聊斋,站在离你最近的地方,眺望你对别人的微笑,即使心是百般的疼痛只为把你的一举一动尽收眼底刺眼的白色,让我明白什么是纯粹的伤害。#include#include#include#define LENGTH 20#define SUBJECT
2、10char subcallSUBJECTLENGTH;int num_of_stu=0;int num_of_sub=0;struct datachar nameLENGTH;char numLENGTH;float scoreSUBJECT;float sum;float aver;struct data *next;void Menu(void);struct data *Append(struct data*);void Check(struct data*);void Modify(struct data*);void List(struct data*);void Search(s
3、truct data*);struct data *Delete(struct data*);struct data *Sort1(struct data*,int (*g)(float,float);void Sort2(struct data*,int (*g)(float,float);int descend(float,float);int ascend(float,float);void main()Menu();void Menu(void)char *choice9=1.Append record,2.Check record,3.Modify record,4.List rec
4、ord,5.Search record,6.Delete record,7.Sort score in descending order,8.Sort score in ascending order,0.exit;struct data *head=NULL;char reply,c;int n=0,k,i;for(i=0;ik)?n:k;while(1)system(cls);printf(ttWelcome to the Students Score Management Systemn); printf(ttt-n); for(i=0;i0;k+) putchar( ); printf
5、(|n);printf(ttt-n);while(1)printf(Please input your choice:); reply=getchar(); if(reply=n)continue;elsec=getchar();if(reply=0&reply1&head=NULL)printf(There is no data stored!n);else switch(reply) case1:head=Append(head);break; case2:Check(head);break; case3:Modify(head);break; case4:List(head);break
6、; case5:Search(head);break; case6:head=Delete(head);break; case7:Sort2(head,descend);break; case8:Sort2(head,ascend);break; default:while(1) printf(Do you really want to exit(Y/N or y/n)?); reply=getchar();if(reply=n)continue;elsec=getchar();if(reply=Y|reply=N|reply=y|reply=n)&c=n)break;else if(c!=n
7、)while(c=getchar()!=n);if(reply=Y|reply=y)free(head);return;while(1) printf(Press ENTER to continue:);scanf(%c,&reply);if(reply=n)break;elsewhile(c=getchar()!=n);struct data *Append(struct data *head)struct data *p;char reply,c;int i;system(cls);if(head=NULL)p=head=(struct data*)malloc(sizeof(struct
8、 data);printf(How many subjects do you want to record(n=%d)?,SUBJECT);scanf(%d%*c,&num_of_sub);for(i=0;inext!=NULL;p=p-next);p-next=(struct data*)malloc(sizeof(struct data);p=p-next; loop:printf(Please input the students name:);scanf(%s%*c,p-name);printf(Please input the students number:);scanf(%s%*
9、c,p-num);p-sum=0;for(i=0;iscorei);p-sum+=p-scorei;p-aver=p-sum/num_of_sub;num_of_stu+;while(1) printf(Do you want to go on appending(Y/N or y/n)?); reply=getchar();if(reply=n)continue;elsec=getchar();if(reply=Y|reply=N|reply=y|reply=n)&c=n)break;else if(c!=n)while(c=getchar()!=n);if(reply=Y|reply=y)
10、p-next=(struct data*)malloc(sizeof(struct data);p=p-next;goto loop;elsep-next=NULL;return head;void Check(struct data *head)struct data *p,*q;struct data *t=(struct data*)malloc(num_of_stu/2*sizeof(struct data*);int minlim,maxlim,n=0,i;system(cls);for(p=head;p!=NULL;p=p-next)for(i=0;iname,(*(t+i)-na
11、me)=0)break;if(inext;q!=NULL;q=q-next)if(strcmp(p-name,q-name)=0)printf(Name %s has been inputed repeatedly!n,p-name);*(t+n)=p;n+;break;printf(Altogether %d name has been repeatedly inputed.n,n);n=0;for(p=head;p!=NULL;p=p-next)for(i=0;inum,(*(t+i)-num)=0)break;if(inext;q!=NULL;q=q-next)if(strcmp(p-n
12、um,q-num)=0)printf(Students number %s has been inputed repeatedly!n,p-num);*(t+n)=p;n+;break;printf(Altogether %d number has been repeatedly inputed.n,n);free(t);n=0;printf(Now check datan);printf(Please input the minimum limit:);scanf(%d%*c,&minlim);printf(Please input the maximum limit:);scanf(%d%
13、*c,&maxlim);if(maxlimnext)for(i=0;iscoreiscoreimaxlim)if(!n)printf(These data has been wrongly inputed:n);printf(%ss %s score.n,p-name,subcalli);n+;printf(Altogether %d wrong data.n,n);void Modify(struct data *head)struct data *p;char modnameLENGTH,modscoreLENGTH;char reply,c;int i;system(cls);do pr
14、intf(Please input the name of the student whose data you want to modify:); scanf(%s%*c,modname); for(p=head;p!=NULL&strcmp(p-name,modname)!=0;p=p-next); if(p=NULL) printf(The student doesnt exist!n); elseprintf(Successfully found!n);while(1) printf(Do you want to modify the students number(Y/N or y/
15、n)?); reply=getchar(); if(reply=n) continue; else c=getchar(); if(reply=Y|reply=N|reply=y|reply=n)&c=n) break; else if(c!=n) while(c=getchar()!=n);if(reply=Y|reply=y)printf(Please input the students new number:);scanf(%s%*c,p-num);while(1) printf(Do you want to modify the students score(Y/N or y/n)?
16、); reply=getchar(); if(reply=n) continue; else c=getchar(); if(reply=Y|reply=N|reply=y|reply=n)&c=n) break; else if(c!=n) while(c=getchar()!=n);if(reply=Y|reply=y) do printf(Please input the name of the subject whose score you want to modify:); scanf(%s%*c,modscore); for(i=0;isum-=p-scorei; printf(P
17、lease input %ss new %s score:,p-name,modscore); scanf(%f%*c,&p-scorei);p-sum+=p-scorei; break; if(i=num_of_sub) printf(The subject doesnt exist!n); while(1) printf(Do you want to go on modifying the students other scores of subject(Y/N or y/n)?); reply=getchar(); if(reply=n) continue; else c=getchar
18、(); if(reply=Y|reply=N|reply=y|reply=n)&c=n) break; else if(c!=n) while(c=getchar()!=n); while(reply=Y|reply=y);p-aver=p-sum/num_of_sub; while(1) printf(Do you want to go on modifying other students data(Y/N or y/n)?); reply=getchar(); if(reply=n) continue; else c=getchar(); if(reply=Y|reply=N|reply
19、=y|reply=n)&c=n) break; else if(c!=n) while(c=getchar()!=n);while(reply=Y|reply=y);void List(struct data *head)struct data *p;int n1=0,n2=0,k,i;system(cls);printf(name );for(p=head;p!=NULL;p=p-next)k=strlen(p-name);n1=(n1k)?n1:k;n1=(n14)?n1:4;for(i=0;inext)k=strlen(p-num);n2=(n2k)?n2:k;n2=(n26)?n2:6
20、;for(i=0;in2-6;i+)putchar( );for(i=0;i0) printf(sum aver);putchar(n);for(p=head;p!=NULL;p=p-next)printf(%s ,p-name);k=strlen(p-name);for(i=0;inum);k=strlen(p-num);for(i=0;in2-k;i+)putchar( );for(i=0;iscorei);k=strlen(subcalli);for(;k-40;k-)putchar( );if(num_of_sub0) printf(%.2f %.2f,p-sum,p-aver);pu
21、tchar(n);printf(Altogether %d records.n,num_of_stu);void Search(struct data *head)struct data *p;char findnameLENGTH=0;char findnumLENGTH=0;char reply,c;int flag,n1,n2,k,i;system(cls);do printf(Do you want to search the student by name(enter 1) or by number(enter 2)?); scanf(%d%*c,&flag);while(flag!
22、=1&flag!=2);doif(flag=1) printf(Please input the name of the student you are finding:); scanf(%s%*c,findname);elseprintf(Please input the number of the student you are finding:);scanf(%s%*c,findnum); for(p=head;p!=NULL;p=p-next)if(strcmp(p-name,findname)=0|strcmp(p-num,findnum)=0) printf(successfull
23、y found:nname );n1=strlen(p-name);n1=(n14)?n1:4; for(i=0;inum);n2=(n26)?n2:6;for(i=0;in2-6;i+)putchar( ); for(i=0;i0) printf(sum aver); putchar(n); printf(%s ,p-name);k=strlen(p-name);for(i=0;inum);k=strlen(p-num);for(i=0;in2-k;i+)putchar( ); for(i=0;iscorei);k=strlen(subcalli); for(;k-40;k-) putcha
24、r( ); if(num_of_sub0) printf(%.2f %.2f,p-sum,p-aver); putchar(n); break;if(p=NULL) printf(The student doesnt exist!n); while(1) printf(Do you want to go on searching(Y/N or y/n)?); reply=getchar(); if(reply=n) continue; else c=getchar(); if(reply=Y|reply=N|reply=y|reply=n)&c=n) break; else if(c!=n)
25、while(c=getchar()!=n);while(reply=Y|reply=y);struct data *Delete(struct data *head)struct data *p,*q;char delnameLENGTH=0;char delnumLENGTH=0;char reply,c;int flag;system(cls);do printf(Do you want to delete all the data(enter 1) or just one students data(enter 2)?); scanf(%d%*c,&flag);while(flag!=1
26、&flag!=2);if(flag=1)num_of_stu=0;free(head);printf(Successfully deleted!n);return NULL;elsedo printf(Do you want to delete the data by name(enter 1) or by number(enter 2)?); scanf(%d%*c,&flag); while(flag!=1&flag!=2);doif(flag=1) printf(Please input the name of the student whose data you want to del
27、ete:); scanf(%s%*c,delname);elseprintf(Please input the number of the student whose data you want to delete:);scanf(%s%*c,delnum);for(p=head;p!=NULL;q=p,p=p-next)if(strcmp(p-name,delname)=0|strcmp(p-num,delnum)=0)if(p=head)head=p-next;elseq-next=p-next;num_of_stu-;free(p);printf(Successfully deleted
28、!n);break;if(p=NULL) printf(The student doesnt exist!n);if(num_of_stu=0)reply=N;else while(1) printf(Do you want to go on deleting(Y/N or y/n)?); reply=getchar(); if(reply=n) continue; else c=getchar(); if(reply=Y|reply=N|reply=y|reply=n)&c=n) break; else if(c!=n) while(c=getchar()!=n);while(reply=Y
29、|reply=y);return head;struct data *Sort1(struct data *head,int (*g)(float,float)struct data *p,*q,*t,*pf=NULL,*qf=NULL,*tf=NULL,*temp;system(cls);for(p=head;p!=NULL;pf=t,p=t-next)t=p;for(q=p-next;q!=NULL;qf=q,q=q-next) if(*g)(q-sum,t-sum)t=q;tf=qf;if(t!=p)if(p=head)head=t;elsepf-next=t;if(t=p-next)p
30、-next=t-next;t-next=p;elsetemp=p-next;p-next=t-next;t-next=temp;tf-next=p;List(head);return head;void Sort2(struct data *head,int (*g)(float,float)struct data *queue=(struct data*)malloc(num_of_stu*sizeof(struct data*);struct data *p,*t;int n1=0,n2=0,k,i,j;system(cls);if(queue=NULL)printf(No enough memory!n);return;while(n1next)for(i=0;inext;p!=NULL;p=p-next) for(i=0;in1;i+) if(p=