C语言课程设计报告学生选修课程系统设计.docx
《C语言课程设计报告学生选修课程系统设计.docx》由会员分享,可在线阅读,更多相关《C语言课程设计报告学生选修课程系统设计.docx(24页珍藏版)》请在冰豆网上搜索。
C语言课程设计报告学生选修课程系统设计
中国地质大学
本科生课程论文封面
课程名称C语言课程设计
教师姓名
本科生姓名
本科生学号
本科生专业
所在院系
类别:
C.本科生
日期:
2012年09月05日
课程设计评语
对课程论文的评语:
平时成绩:
课程论文成绩:
总成绩:
评阅人签名:
注:
1、无评阅人签名成绩无效;
2、必须用钢笔或圆珠笔批阅,用铅笔阅卷无效;
3、如有平时成绩,必须在上面评分表中标出,并计算入总成绩。
1.课程论文题目
名称:
学生选修课系统设计
【要求】
假定有n门课程,每门课程有课程编号,课程名称,课程性质,总学时,授课时间,实验或上级时间,学分,开课学期等信息,学生可按要求(如总学分不超过60)自由选课。
是设计一选修课课程系统,使只能提供以下功能:
(1)系统一菜单方式工作
(2)课程信息和学生选课信息录入功能(课程信息用文件保存
输入
(3)课程信息浏览功能——输出
(4)查询功能(至少一种查询方式)——算法
(5)按学分查询
(6)某门课程学生选修情况(可选项)
【提示】
数据结构可用结构体,包括授课和选课两个结构体,其中课程结构体成员包括编号,课程名称,课程性质,总学时,授课学时,实验或上机时间,学分,开课学期。
学秀结构体成员包括学号,课程编号,该结构体的建立主要是为了查询某门课程学生选修情况。
2.程序设计思路
由于题目要求将学生的选课信息用结构体形式输入,并写入文件中,所以应提供文件的输入输出等操作:
在过程中需有浏览、插入、修改、查找、删除学生选课信息等操作,顾应分别建立个功能模块;另外还应提供键盘式选择菜单实现程序运行。
根据题目要求,可以将系统分为六个模块:
1)系统以菜单方式工作模块;
2)课程信息与学生选课信息录入功能模块;
3)课程信息浏览功能模块;
4)查询模块;
5)按学分查询模块;
6)某些课程学生选修情况模块
3.功能模块图
4.数据结构设计
该程序采用多个main()函数模块分别来实现程序的运行,通过使用数组功能来实现数据的录入,使用strcpy()函数来实现录入信息的复制,整个结构从整体来看使用了选择结构,break..case..的合理利用
5.算法设计
1.课程信息录入功能
voidsavefile(SUB*head)
{
SUB*p;
FILE*fp;
fp=fopen("subjects.txt","w");
fprintf(fp,"课程编号课程名称课程性质总学时授课学时实验或上机学时学分开课学期\n");
for(p=head;p;p=p->next)
fprintf(fp,"%5d%12s%9s%9d%9d%11d%11d%7d\n",p->num,p->name,p->kind,p->stime,p->ttime,p->etime,p->score,p->term);
fclose(fp);
}
voidsavefileadd(SUB*head)
{
SUB*p;
FILE*fp;
fp=fopen("subjectsadd.txt","w");
fprintf(fp,"课程编号课程名称课程性质总学时授课学时实验或上机学时学分开课学期\n");
for(p=head;p;p=p->next)
fprintf(fp,"%5d%12s%9s%9d%9d%11d%11d%7d\n",p->num,p->name,p->kind,p->stime,p->ttime,p->etime,p->score,p->term);
fclose(fp);
}
2.查询功能
voidsearch(SUB*head)
{
inta,num;
intt=1;
chartype[10];
charch='a',ch1;
SUB*ptr;
while(ch!
=''){
printf("若要按课程性质查找请输入1,若要按学分查找请输入2:
\n");
scanf("%d",&a);
switch(a){
case1:
printf("请输入要查找的课程的性质:
\n");
scanf("%s",type);
printf("课程编号课程名称课程性质总学时授课学时实践或上机学时学分开课学期\n");
for(ptr=head;ptr;ptr=ptr->next)
if(strcmp(type,ptr->kind)==0){
printf("%5d%12s%9s%9d%9d%11d%11d%7d\n",ptr->num,ptr->name,ptr->kind,ptr->stime,ptr->ttime,ptr->etime,ptr->score,ptr->term);
t=0;
}
if(t)printf("未找到!
\n");
t=1;
break;
case2:
printf("输入要查找的课程的学分\n");
scanf("%d",&num);
printf("课程编号课程名称课程性质总学时授课学时实践或上机学时学分开课学期\n");
for(ptr=head;ptr;ptr=ptr->next)
if(ptr->score==num){
printf("%5d%12s%9s%9d%9d%11d%11d%7d\n",ptr->num,ptr->name,ptr->kind,ptr->stime,ptr->ttime,ptr->etime,ptr->score,ptr->term);
t=0;
}
if(t)printf("未找到!
\n");
t=1;
}
printf("继续查找请按回车键,结束请按空格键:
\n");
ch1=getchar();//将回车键赋给CH1,否则CASE里面最后输入的回车键会赋给CH,因此用CH1填补。
ch=getchar();
}
}
3.插入、删除信息功能
SUB*insert(SUB*head)
{
SUB*ptr,*ptr2,*subj;
intsize=sizeof(SUB);
charch='a',ch1;
while(ch!
=''){
subj=(SUB*)malloc(size);
ptr=subj;
printf("输入要插入的课程信息:
\n");
scanf("%d%s%s%d%d%d%d%d",&subj->num,subj->name,subj->kind,&subj->stime,&subj->ttime,&subj->etime,&subj->score,&subj->term);
if(head==NULL){
head=ptr;
head->next=NULL;
}
else{
for(ptr2=head;ptr2;ptr2=ptr2->next)
if(ptr2->next==NULL){
ptr2->next=subj;
subj->next=NULL;
break;
}
}
printf("继续插入请按回车,结束请按空格:
\n");
ch1=getchar();//将回车键赋给CH1,否则subj->term输完后输入的回车键会赋给CH,因此用CH1填补。
ch=getchar();
}
returnhead;
}
SUB*del(SUB*head)
{
SUB*p1,*p2;
charch='a',ch1;
intnum;
while(ch!
=''){
printf("输入想要删除的课程编号:
\n");
scanf("%d",&num);
if(head->num==num){
p2=head;
head=head->next;
free(p2);
}
if(head==NULL)
returnNULL;
p1=head;
p2=head->next;
while(p2){
if(p2->num==num){
p1->next=p2->next;
free(p2);
}
elsep1=p2;
p2=p1->next;
}
printf("继续删除请按回车,结束请按空格:
\n");
ch1=getchar();//将回车键赋给CH1,否则num输完后再输入的回车键会赋给CH,因此用CH1填补。
ch=getchar();
}
returnhead;
}
4.选课功能
voidchoose(SUB*head)
{
SUB*p,*q;
inta[5];
intnum,total=0,i=0,j;
printf("输入要选修的课程的编号,编号之间以空格分开,输完后以0结束\n");
scanf("%d",&num);
while(num!
=0){
for(p=head;p;p=p->next)
if(p->num==num){
total=total+p->score;
a[i]=num;
i++;
}
scanf("%d",&num);
}
if(total<60)printf("选修总学分未达到60,选修失败!
\n");
else{
printf("选修成功!
\n");
printf("您选修的课程为:
\n");
for(j=0;j
for(q=head;q;q=q->next)
if(q->num==a[j])
printf("%s",q->name);
printf("\n");
printf("***********************************\n");
printf("***********************************\n");
printf("***********************************\n");
printf("***********************************\n");
}
6.程序代码
#include
#include
#include
typedefstructsubjects
{
intnum;
charname[20];
charkind[10];
intstime;
intttime;
intetime;
intscore;
intterm;
structsubjects*next;
}SUB;
SUB*create_form()
{
SUB*head,*tail,*p;
intnum,stime,ttime;
intetime,score,term;
charname[20],kind[10];
intsize=sizeof(SUB);
head=tail=NULL;
printf("输入选修课程信息:
\n");
scanf("%d%s%s%d%d%d%d%d",&num,&name,&kind,&stime,&ttime,&etime,&score,&term);
while(num!
=0){
p=(SUB*)malloc(size);
p->num=num;
strcpy(p->name,name);
strcpy(p->kind,kind);
p->stime=stime;
p->ttime=ttime;
p->etime=etime;
p->score=score;
p->term=term;
if(head==NULL)
head=p;
else
tail->next=p;
tail=p;
scanf("%d%s%s%d%d%d%d%d",&num,&name,&kind,&stime,&ttime,&etime,&score,&term);
}
tail->next=NULL;
returnhead;
}
voidsavefile(SUB*head)
{
SUB*p;
FILE*fp;
fp=fopen("subjects.txt","w");
fprintf(fp,"课程编号课程名称课程性质总学时授课学时实验或上机学时学分开课学期\n");
for(p=head;p;p=p->next)
fprintf(fp,"%5d%12s%9s%9d%9d%11d%11d%7d\n",p->num,p->name,p->kind,p->stime,p->ttime,p->etime,p->score,p->term);
fclose(fp);
}
voidsavefileadd(SUB*head)
{
SUB*p;
FILE*fp;
fp=fopen("subjectsadd.txt","w");
fprintf(fp,"课程编号课程名称课程性质总学时授课学时实验或上机学时学分开课学期\n");
for(p=head;p;p=p->next)
fprintf(fp,"%5d%12s%9s%9d%9d%11d%11d%7d\n",p->num,p->name,p->kind,p->stime,p->ttime,p->etime,p->score,p->term);
fclose(fp);
}
voidsavefiledel(SUB*head)
{
SUB*p;
FILE*fp;
fp=fopen("subjectsdel.txt","w");
fprintf(fp,"课程编号课程名称课程性质总学时授课学时实验或上机学时学分开课学期\n");
for(p=head;p;p=p->next)
fprintf(fp,"%5d%12s%9s%9d%9d%11d%11d%7d\n",p->num,p->name,p->kind,p->stime,p->ttime,p->etime,p->score,p->term);
fclose(fp);
}
voidprin(SUB*head)
{
SUB*ptr;
if(head==NULL){
printf("没有此门课程记录!
\n");
return;
}
printf("课程编号课程名称课程性质总学时授课学时实践或上机学时学分开课学期\n");
for(ptr=head;ptr;ptr=ptr->next)
printf("%5d%12s%9s%9d%9d%11d%11d%7d\n",ptr->num,ptr->name,ptr->kind,ptr->stime,ptr->ttime,ptr->etime,ptr->score,ptr->term);
}
voidsearch(SUB*head)
{
inta,num;
intt=1;
chartype[10];
charch='a',ch1;
SUB*ptr;
while(ch!
=''){
printf("若要按课程性质查找请输入1,若要按学分查找请输入2:
\n");
scanf("%d",&a);
switch(a){
case1:
printf("请输入要查找的课程的性质:
\n");
scanf("%s",type);
printf("课程编号课程名称课程性质总学时授课学时实践或上机学时学分开课学期\n");
for(ptr=head;ptr;ptr=ptr->next)
if(strcmp(type,ptr->kind)==0){
printf("%5d%12s%9s%9d%9d%11d%11d%7d\n",ptr->num,ptr->name,ptr->kind,ptr->stime,ptr->ttime,ptr->etime,ptr->score,ptr->term);
t=0;
}
if(t)printf("未找到!
\n");
t=1;
break;
case2:
printf("输入要查找的课程的学分\n");
scanf("%d",&num);
printf("课程编号课程名称课程性质总学时授课学时实践或上机学时学分开课学期\n");
for(ptr=head;ptr;ptr=ptr->next)
if(ptr->score==num){
printf("%5d%12s%9s%9d%9d%11d%11d%7d\n",ptr->num,ptr->name,ptr->kind,ptr->stime,ptr->ttime,ptr->etime,ptr->score,ptr->term);
t=0;
}
if(t)printf("未找到!
\n");
t=1;
}
printf("继续查找请按回车键,结束请按空格键:
\n");
ch1=getchar();//将回车键赋给CH1,否则CASE里面最后输入的回车键会赋给CH,因此用CH1填补。
ch=getchar();
}
}
SUB*insert(SUB*head)
{
SUB*ptr,*ptr2,*subj;
intsize=sizeof(SUB);
charch='a',ch1;
while(ch!
=''){
subj=(SUB*)malloc(size);
ptr=subj;
printf("输入要插入的课程信息:
\n");
scanf("%d%s%s%d%d%d%d%d",&subj->num,subj->name,subj->kind,&subj->stime,&subj->ttime,&subj->etime,&subj->score,&subj->term);
if(head==NULL){
head=ptr;
head->next=NULL;
}
else{
for(ptr2=head;ptr2;ptr2=ptr2->next)
if(ptr2->next==NULL){
ptr2->next=subj;
subj->next=NULL;
break;
}
}
printf("继续插入请按回车,结束请按空格:
\n");
ch1=getchar();//将回车键赋给CH1,否则subj->term输完后输入的回车键会赋给CH,因此用CH1填补。
ch=getchar();
}
returnhead;
}
SUB*del(SUB*head)
{
SUB*p1,*p2;
charch='a',ch1;
intnum;
while(ch!
=''){
printf("输入想要删除的课程编号:
\n");
scanf("%d",&num);
if(head->num==num){
p2=head;
head=head->next;
free(p2);
}
if(head==NULL)
returnNULL;
p1=head;
p2=head->next;
while(p2){
if(p2->num==num){
p1->next=p2->next;
free(p2);
}
elsep1=p2;
p2=p1->next;
}
printf("继续删除请按回车,结束请按空格:
\n");
ch1=getchar();//将回车键赋给CH1,否则num输完后再输入的回车键会赋给CH,因此用CH1填补。
ch=getchar();
}
returnhead;
}
voidchoose(SUB*head)
{
SUB*p,*q;
inta[5];
intnum,total=0,i=0,j;
printf("输入要选修的课程的编号,编号之间以空格分开,输完后以0结束\n");
scanf("%d",&num);
while(num!
=0){
for(p=head;p;p=p->next)
if(p->num==num){
total=total+p->score;
a[i]=num;
i++;
}
scanf("%d",&num);
}
if(total<60)printf("选修总学分未达到60,选修失败!
\n");
else{
printf("选修成功!
\n");
printf("您选修的课程为:
\n");
for(j=0;j
for(q=head;q;q=q->next)
if(q->num==a[j])
printf("%s",q->name);
printf("\n");
printf("***********************************\n");
printf("**********************************\n");
printf("**********************************\n");
printf("***********************************\n");
}
}
voidmain()
{
SUB*head=create_form();
savefile(head);
prin(head);
search(head);
head=insert(head);//注意此处的必要性,函数insert的的返回值重新赋给head!
savefileadd(head);
printf("修改后的信息为:
\n");
prin(head);
head=del(head);//注意此处的必要性,函数del的的返回值重新赋给head!
savefiledel(head);
printf("修改后的课程信息为:
\n");
prin(head);
choose(head);
}
7.程序运行结果
7.编程中遇到的困难及解决方法
1.问题:
程序虽然经过多次精简,但仅仅是形式上、小范围的精简,仍未得到本质上的精简,即未找到更加简单、更加高效、更加合理、更小占用的资源的算法。
解决方法:
.算法上除了采用结构体数组外,考虑在程序的算法设计上引入链表结构,考察这样对数据组织存贮效率上是否具有提高作用
2.