ImageVerifierCode 换一换
格式:DOC , 页数:35 ,大小:53.04KB ,
资源ID:3611043      下载积分:12 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/3611043.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(VC综合实验图书馆管理系统.doc)为本站上传会员【快乐****生活】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

VC综合实验图书馆管理系统.doc

1、VC++综合试验 图书馆管理系统.txt都是一种山旳狐狸,你跟我讲什么聊斋,站在离你近来旳地方,眺望你对他人旳微笑,虽然心是百般旳疼痛 只为把你旳一举一动尽收眼底.耀眼旳白色,让我明白什么是纯粹旳伤害。#include #include #include #define LENGTH 20 #define SUBJECT 10 char subcall[SUBJECT][LENGTH]; int num_of_stu=0; int num_of_sub=0; struct data { char name[LENG

2、TH]; char num[LENGTH]; float score[SUBJECT]; 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(struct data*); struct data *Delete(struct data*);

3、 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 *choice[9]={"1.Append record","2.Check record","3.Modify record","4.List record","5.S

4、earch 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;i<9;i++) { k=strlen(choice[i]); n=(n>k)?n:k; } while(1) { system("cls"); printf("\t\tWelcome to the S

5、tudents' Score Management System\n"); printf("\t\t\t-----------------------------------\n"); for(i=0;i<9;i++) { printf("\t\t\t| %s",choice[i]); k=strlen(choice[i]); for(;n-k>0;k++) putchar(' '); printf("|\n"); } printf("\t\t\t-----------------

6、\n"); while(1) { printf("Please input your choice:"); reply=getchar(); if(reply=='\n') continue; else c=getchar(); if(reply>='0'&&reply<='8'&&c=='\n') break; else if(c!='\n') while(c=getchar()!='\n'); printf("There is n

7、o such choice!\n"); } if(reply>'1'&&head==NULL) printf("There is no data stored!\n"); else { switch(reply) { case'1':head=Append(head);break; case'2':Check(head);break; case'3':Modify(head);break; case'4':List(head);break;

8、 case'5':Search(head);break; case'6':head=Delete(head);break; case'7':Sort2(head,descend);break; case'8':Sort2(head,ascend);break; default:while(1) { printf("Do you really want to exit(Y/N or y/n)?"); reply=getchar();

9、 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') { free(head); return;

10、 } } } while(1) { printf("Press ENTER to continue:"); scanf("%c",&reply); if(reply=='\n') break; else while(c=getchar()!='\n'); } } } struct data *Append(struct data *head) { struct data *p; char reply,c; int i; system("cls"); if(head=

11、NULL) { p=head=(struct data*)malloc(sizeof(struct data)); printf("How many subjects do you want to record(n<=%d)?",SUBJECT); scanf("%d%*c",&num_of_sub); for(i=0;i

12、 for(p=head;p->next!=NULL;p=p->next); p->next=(struct data*)malloc(sizeof(struct data)); p=p->next; } loop:printf("Please input the student's name:"); scanf("%s%*c",p->name); printf("Please input the student's number:"); scanf("%s%*c",p->num); p->sum=0; for(i=0;i

13、i++) { printf("Please input the student's %s score:",subcall[i]); scanf("%f%*c",&p->score[i]); p->sum+=p->score[i]; } 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')

14、 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') { p->next=(struct data*)malloc(sizeof(struct data)); p=p->next; goto loop; } else { p

15、>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

16、))->name)==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 repeatedl

17、y 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->num,q->num)==0) { printf("Student's number %s has been inputed re

18、peatedly!\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 data\n"); printf("Please input the minimum limit:"); scanf("%d%*c",&minlim); printf("Please input the maximum limit

19、"); scanf("%d%*c",&maxlim); if(maxlimnext) { for(i=0;iscore[i]score[i]>maxlim) { if(!n) printf("These data has been wrongly inputed:\n"); print

20、f("%s's %s score.\n",p->name,subcall[i]); n++; } } } printf("Altogether %d wrong data.\n",n); } void Modify(struct data *head) { struct data *p; char modname[LENGTH],modscore[LENGTH]; char reply,c; int i; system("cls"); do { printf("Please input the name of the

21、 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 doesn't exist!\n"); else { printf("Successfully found!\n"); while(1) { printf(

22、"Do you want to modify the student's number(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')

23、 while(c=getchar()!='\n'); } if(reply=='Y'||reply=='y') { printf("Please input the student's new number:"); scanf("%s%*c",p->num); } while(1) { printf("Do you want to modify the student's score(Y/N or y/n)?"); reply=getchar

24、); 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') {

25、 do { printf("Please input the name of the subject whose score you want to modify:"); scanf("%s%*c",modscore); for(i=0;isum-=p->score[i]; pri

26、ntf("Please input %s's new %s score:",p->name,modscore); scanf("%f%*c",&p->score[i]); p->sum+=p->score[i]; break; } } if(i==num_of_sub) printf("The subject doesn't exist!\n"); while(1) {

27、 printf("Do you want to go on modifying the student's other scores of subject(Y/N or y/n)?"); reply=getchar(); if(reply=='\n') continue; else c=getchar(); if((reply=='Y'||reply==

28、'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

29、 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=='y'||reply=='n')&&c=='\n') break; else if(c!='\n') while(c=getchar()!='\n');

30、 } } 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=(n1>k)?n1:k; } n1=(n1>4)?n1:4; for(i=0;i

31、"number "); for(p=head;p!=NULL;p=p->next) { k=strlen(p->num); n2=(n2>k)?n2:k; } n2=(n2>6)?n2:6; for(i=0;i0) printf("sum aver"); putchar('\n'); for(p=head;p!=NULL;p=p->nex

32、t) { printf("%s ",p->name); k=strlen(p->name); for(i=0;inum); k=strlen(p->num); for(i=0;iscore[i]); k=strlen(subcall[i]); for(;k-4>0;k--)

33、 putchar(' '); } if(num_of_sub>0) printf("%.2f %.2f",p->sum,p->aver); putchar('\n'); } printf("Altogether %d records.\n",num_of_stu); } void Search(struct data *head) { struct data *p; char findname[LENGTH]={'\0'}; char findnum[LENGTH]={'\0'}; char reply,c; int flag,

34、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!=1&&flag!=2); do { if(flag==1) { printf("Please input the name of the student you are finding:");

35、 scanf("%s%*c",findname); } else { printf("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("successfully found:\nname

36、"); n1=strlen(p->name); n1=(n1>4)?n1:4; for(i=0;inum); n2=(n2>6)?n2:6; for(i=0;i

37、 if(num_of_sub>0) printf("sum aver"); putchar('\n'); printf("%s ",p->name); k=strlen(p->name); for(i=0;inum); k=strlen(p->num); for(i=0;i

38、0;iscore[i]); k=strlen(subcall[i]); for(;k-4>0;k--) putchar(' '); } if(num_of_sub>0) printf("%.2f %.2f",p->sum,p->aver); putchar('\n'); break; } } if(p==NULL)

39、 printf("The student doesn't 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==

40、'\n') break; else if(c!='\n') while(c=getchar()!='\n'); } } while(reply=='Y'||reply=='y'); } struct data *Delete(struct data *head) { struct data *p,*q; char delname[LENGTH]={'\0'}; char delnum[LENGTH]={'\0'}; char reply,c; int flag; system("cls"); do

41、 { printf("Do you want to delete all the data(enter 1) or just one student's data(enter 2)?"); scanf("%d%*c",&flag); } while(flag!=1&&flag!=2); if(flag==1) { num_of_stu=0; free(head); printf("Successfully deleted!\n"); return NULL; } else { do {

42、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); do { if(flag==1) { printf("Please input the name of the student whose data you want to delete:"); scanf("%s%*c",de

43、lname); } else { printf("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;

44、 else q->next=p->next; num_of_stu--; free(p); printf("Successfully deleted!\n"); break; } } if(p==NULL) printf("The student doesn't exist!\n"); if(num_of_stu==0) reply='N'; else { while(1) {

45、 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;

46、 else if(c!='\n') while(c=getchar()!='\n'); } } } while(reply=='Y'||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!

47、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; else pf->next=t; if(t==p->next) { p->next=t->next; t->next=p; } el

48、se { temp=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,n

49、2=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

50、) { for(i=0;isum,t->sum)) t=p; } queue[n1]=t; n1++; } n1=0; printf("name "); for(i=0;iname); n1=(n1>

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服