totaltotal) { p2=p[k]; p[k]=p[j]; p[j]=p2; } //从大到小排列的指针 for(i=0;iid <name <sex <score[0] <score[1] <score[2] <score[3] <total/4.0 <total<求各科平均分成绩的函数 void Information::average(student *head) { int k,m; float arg1=0,arg2=0,arg3=0,arg4=0; if(head==NULL)//如果头指针是空则继续 { cout<<" 这是一个空表,请先输入考生成绩.\n"; } else { m=count(head); p1=head; for(k=0;kscore[0]; arg2+=p1->score[1]; arg3+=p1->score[2]; arg4+=p1->score[3]; p1=p1->next; } arg1/=m;arg2/=m;arg3/=m;arg4/=m; cout<<"全班单科成绩平均分\n"; cout<<"------------------------------------------------------------------------------\n"; cout<<" 计算机组成原理平均分:"<保存函数. void Information::save(student *head) { ofstream out("data.txt",ios::out); out<name<<"\t" <id<<"\t"<<"\t" <sex<<"\t" <score[0]<<"\t" <score[1]<<"\t" <score[2]<<"\t" <score[3]<<"\t" <total<next; } } //———————————>读取函数的实现 student *Information::Read() { int i=0; p1=p2=( student *)malloc(LEN); head=NULL; ifstream in("data.txt",ios::out); in>>i; if(i==0){cout<<" data.txt 文件中的数据为空,请先输入数据。"<0;i--) { p1=(student *)malloc(LEN); cin>>st.name>>st.id>>st.sex >>st.score[0]>>st.score[1]>>st.score[2]>>st.score[3] >>st.total; strcpy(p1->name,st.name); p1->id=st.id; strcpy(p1->sex,st.sex); p1->score[0]=st.score[0]; p1->score[1]=st.score[1]; p1->score[2]=st.score[2]; p1->score[3]=st.score[3]; p1->total=st.total; if(n==0)head=p1;//如果是输入第一组学生考试信息就将指针p1赋给指针head else p2->next=p1;//否则将p1赋给p2所指结构体的next指针 p2=p1;//将指针p1赋给指针p2 n++; //将n的值加1 //显示读入数据 cout<<" "<name<<"\t" <id<<"\t"<<"\t" <sex<<"\t" <score[0]<<"\t" <score[1]<<"\t" <score[2]<<"\t" <score[3]<<"\t" <total<next=NULL; return (head); } } //------------------------------>主函数. int main(void) { Information person; student *head=NULL; char str[10]; int flag=0; int choice; long int i; head=person.Read(); do{ cout<<"┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓"<>str; if(atoi(str)>7 || atoi(str)<1) cout<<"对不起,请输入1-7这几个数字!!\n"; else { choice=atoi(str); switch(choice) { case 1: head=person.creat(); break; case 2: person.output(head); break; case 3: person.inorder(head); person.average(head); cout<<" 参加考试的学生人数为:"<>str; if(atol(str)>99999999 || atol(str)<1) cout<<"对不起,请输入正确输入!!!\n"; else {i=atol(str); flag=1; } }while(flag==0); flag=0; person.find(head,i); break; case 5: head=person.insert(head); person.output(head); break; case 6: cout<<" 请输入要删除的准考证号(8位):"; do{ cin>>str; if(atol(str)>99999999 || atol(str)<1) cout<<"对不起,请输入正确输入!!!h\n"; else {i=atol(str); flag=1; } }while(flag==0); flag=0; head=person.cancel(head,i); person.output(head); break; case 7: person.save(head); cout<<"文件已保存!可以安全退出!!!"<> 相关内容 • 求毕业
论文
政研论文下载论文大学下载论文大学下载关于长拳的论文浙大论文封面下载
VC“学生信息管理系统” 2010-5-25 • 用VC++做“学生信息管理系统”的登录界面 3 2008-3-19 • 谁能帮我vc++做个学生信息管理系统 5 2008-5-29 • 用VC编写一个学生信息管理系统 2008-7-5 • 谁能提供一下用VC++制作一个学生信息管理系统的代码的啊?? 1 2010-7-4 更多关于vc 学生管理系统的问
题
快递公司问题件快递公司问题件货款处理关于圆的周长面积重点题型关于解方程组的题及答案关于南海问题
>> 查看同主题问题: 学生信息管理系统 等待您来回答更多 0回答 谁有《易学C++》这本
书
关于书的成语关于读书的排比句社区图书漂流公约怎么写关于读书的小报汉书pdf
的电子版帮忙发带407066663@qq.com 0回答 20 Linux windows socket 传输问题 0回答 C++简单问题,谢谢。 0回答 苹果电脑YY语音的声卡驱动在哪里? QQ757066637 0回答 荣成方正房地产公司开发的宝月山庄怎么样 0回答 c语言中(a)>(b) ? (a):(b)什么意思 0回答 急!!!在线等!!! 0回答 屡败屡战说明了什么道理 其他回答 共 1 条 #include #include #include struct stud { long num; char name[20]; double score; }; typedef struct stucode { struct stud student ; struct stucode *next; }L; void menu(); void createlist(struct stucode **r); void out(struct stucode *r); void search1(struct stucode *r); void search2(struct stucode *r); void del(struct stucode **r); void insert(struct stucode **r); void sort(struct stucode **r); void main() { char choose; int flag=1; struct stucode *r=NULL; while(flag) { system("cls"); menu(); choose=getchar(); switch(choose) { case '1': createlist(&r); out(r); printf("Testing function 1\nPress any key to continue\n"); getchar(); getchar(); break; case '2': search1(r); printf("Testing function 1\nPress any key to continue\n"); getchar(); getchar(); break; case '3': search2(r); printf("Testing function 1\nPress any key to continue\n"); getchar(); getchar(); break; case '4': del(&r); out(r); printf("Testing function 1\nPress any key to continue\n"); getchar(); getchar(); break; case '5': insert(&r); out(r); printf("Testing function 1\nPress any key to continue\n"); getchar(); getchar(); break; case '6': sort(&r); out(r); printf("Testing function 1\nPress any key to continue\n"); getchar(); getchar(); break; case '7': out(r); printf("Testing function 7\nPress any key to continue\n"); getchar(); getchar(); break; case '0': flag=0; printf("The end.\n"); break; default: printf("\nWrong Selection!(选择错误,请重选!)\n");getchar();getchar(); } } } void createlist(struct stucode **r) { struct stucode *p,*t; long n; char a[20]; double s; if(*r) *r=NULL; printf(" \n请输入:\n 学号(请按学号升序排列) 姓名 分数 (若要结束请输入三个为零)\n"); scanf("%ld%s%lf",&n,a,&s); if(n==0) return; p=(L *)malloc(sizeof(L)); p->student.num=n; strcpy(p->student.name,a); p->student.score=s; p->next=NULL; *r=p; scanf("%ld%s%lf",&n,a,&s); while(n) { t=p; p=(L *)malloc(sizeof(L)); p->student.num=n; strcpy(p->student.name,a); p->student.score=s; p->next=NULL; t->next=p; scanf("%ld%s%lf",&n,a,&s); } } void search1(struct stucode *r) { long x; if(!r) { printf("没有学生信息可查询!\n"); return ; } printf(" 请输入要查询的学生信息的学生学号:\n"); scanf("%ld",&x); while(r&&r->student.num!=x) r=r->next; if(r==NULL) printf("Error! No such student !\n"); else printf("%ld %s %.2lf\n",r->student.num,r->student.name,r->student.score); } void search2(struct stucode *r) { char m[20]; if(!r) { printf("没有学生信息可查询!\n"); return ; } printf(" 请输入要查询的学生信息的学生姓名:\n"); scanf("%s",m); while(r&&strcmp(r->student.name,m)) r=r->next; if(r==NULL) printf("Error! No such student !\n"); else printf("%ld %s %.2lf\n",r->student.num,r->student.name,r->student.score); } void del(struct stucode **r) { long k; struct stucode *p=*r,*t; if(!(*r)) { printf("没有学生信息可删除 !\n"); return ; } printf(" 请输入要删除的学生信息的学生学号:\n"); scanf("%ld",&k); if(p->student.num==k) *r=(*r)->next,free(p); else { while(p->next&&p->next->student.num!=k) p=p->next; if(p->next==NULL) printf("Error! No such student !\n"); else { t=p->next; p->next=p->next->next; free(t); } } } void insert(struct stucode **r) { long n; char a[20]; double s; L *p,*t,*k; printf(" 请输入要插入的学生信息的学生学号 姓名 分数:\n"); scanf("%ld%s%lf",&n,a,&s); p=(L *)malloc(sizeof(L)); p->student.num=n; p->student.score=s; strcpy(p->student.name,a); if(!(*r)) { *r=p; (*r)->next=NULL; return ; } if(p->student.num<(*r)->student.num) p->next=(*r),(*r)=p; else { t=*r; k=t; while(t->next&&t->next->student.num<=p->student.num) t=t->next; p->next=t->next; t->next=p; *r=k; } } void sort(struct stucode **r) { struct stucode *t,*p,*q,*z; if(!r) { printf("没有学生信息可排序!\n"); return ; } if(!(*r)||!(*r)->next) return; t=*r; p=t->next; t->next=NULL; while(p) { q=p->next; if(p->student.score>t->student.score) { p->next=t; t=p; } else { z=t; while(z->next&&z->next->student.score>=p->student.score) z=z->next; p->next=z->next; z->next=p; } p=q; } *r=t; } void out(struct stucode *r) { printf("\n\n"); if(!r) { printf("没有学生信息可输出!\n"); return ; } while(r) { printf("%ld %s %.2lf\n",r->student.num,r->student.name,r->student.score); r=r->next; } printf("\n\n"); } void menu() { printf("\n 学生信息管理系统\n"); printf("\n 菜单\n\n"); printf("\n 1建立链表并显示\n"); printf("\n 2查找某学号的学生信息\n"); printf("\n 3查找某姓名的学生信息\n"); printf("\n 4删除某学号的学生信息\n"); printf("\n 5插入新的学生信息\n"); printf("\n 6按分数降序排列输出\n"); printf("\n 7输出\n"); printf("\n 0退出\n"); printf("\n 请选择您要执行的选项:\n"); }