学生选课系统代码Word下载.docx
- 文档编号:18870206
- 上传时间:2023-01-01
- 格式:DOCX
- 页数:24
- 大小:17.35KB
学生选课系统代码Word下载.docx
《学生选课系统代码Word下载.docx》由会员分享,可在线阅读,更多相关《学生选课系统代码Word下载.docx(24页珍藏版)》请在冰豆网上搜索。
printf("
课程编号\t课程名称\t学分\t课程人数上限\n"
);
scanf("
%d%s%d%d"
&
p1->
num1,p1->
name1,&
score,&
Melepeo);
nelepeo=0;
head1=NULL;
while(p1->
num1!
=0)
N1=N1+1;
%
if(N1==1)head1=p1;
elsep2->
next=p1;
p2=p1;
p1=(structcouse*)malloc(sizeof(structcouse));
p2->
next=NULL;
voidfilec()
.
FILE*fp;
charfilepath[20];
输入要读入的文件路径:
"
getchar();
gets(filepath);
if((fp=fopen(filepath,"
r"
))==NULL)
{
@
找不到%s文件!
\n"
filepath);
exit(0);
}
fscanf(fp,"
%d%s%d%d%d"
nelepeo,&
while(!
feof(fp))
N1=N1+1;
《
voidinputc()
inti;
(
\t\t\t录入课程信息\n"
printf("
\n1.从键盘录入\n"
2.从文件录入\n"
3.返回主菜单\n"
请选择(1~3):
scanf("
%d"
i);
switch(i)
case
(1):
keyboardc();
break;
case
(2):
filec();
【
case(3):
voidinsertc(structcouse*incouse)
structcouse*p0,*p1,*p2;
p1=head1;
p0=incouse;
if(head1==NULL)
…
head1=p0;
p0->
else
while((p0->
num1>
p1->
num1)&
&
(p1->
next!
=NULL))
{
p2=p1;
p1=p1->
next;
}
if(p0->
num1<
=p1->
num1)
if(head1==p1)head1=p0;
elsep2->
next=p0;
else
p0->
~
voiddelc(intnum1)
\n没有课程,无法删除!
)
gotoend;
p1=head1;
while(num1!
=p1->
num1&
=NULL)
if(num1==p1->
[
if(p1==head1)head1=p1->
next=p1->
已删除该编号课程!
N1=N1-1;
elseprintf("
无该编号的课程!
end:
;
voidmanagementc()
structcouse*incouse;
inti,num1;
\t\t\t课程管理\n"
1.新增课程\n"
2.删除课程\n"
incouse=(structcouse*)malloc(sizeof(structcouse));
incouse->
num1,incouse->
insertc(incouse);
请输入要删除课程的编号:
num1);
delc(num1);
voidkeyboards()
^
inti;
structstudent*p1,*p2;
N2=0;
p1=p2=(structstudent*)malloc(sizeof(structstudent));
学生学号\t学生姓名\n"
%d%s"
num2,p1->
name2);
nelen=0;
for(i=0;
i<
20;
i++)p1->
nelenum[i]=0;
head2=NULL;
num2!
N2=N2+1;
if(N2==1)head2=p1;
p1=(structstudent*)malloc(sizeof(structstudent));
voidfiles()
inti=0;
|
p1=p2=(structstudent*)malloc(sizeof(structstudent));
fread(p1,sizeof(structstudent),1,fp);
,
i=0;
#
voidinputs()
\t\t\t录入学生信息\n"
keyboards();
files();
voidinserts(structstudent*incouse)
?
structstudent*p0,*p1,*p2;
p1=head2;
if(head2==NULL)
head2=p0;
—
num2>
num2)&
p1=p1->
if(p0->
num2<
num2)
if(head2==p1)head2=p0;
!
voiddels(intnum2)
\n没有该学生信息,无法删除!
while(num2!
num2&
:
if(num2==p1->
if(p1==head2)head2=p1->
已删除该学生信息!
N2=N2-1;
无该学号的学生!
voidmanagements()
structstudent*incouse;
inti,num2;
\t\t\t学生信息管理\n"
1.新增学生信息\n"
2.删除学生信息\n"
incouse=(structstudent*)malloc(sizeof(structstudent));
nelenum[0]=0;
num2,incouse->
inserts(incouse);
请输入要删除学生的学号:
num2);
、
dels(num2);
voidelect(structstudent*s)
structcouse*p;
intnum1,i;
请输入要选课的编号:
s->
nelenum[i]!
=0;
i++);
nelenum[i]=num1;
(s->
nelen)++;
p=head1;
while(p->
=num1)p=p->
(p->
nelepeo)++;
voidcheak()
chare;
structcouse*c;
structstudent*s;
intnum2,i,j=0,t=0;
请输入你的学号:
s=head2;
while(s->
=num2&
s->
=NULL)s=s->
if(s->
=num2)
]
不存在你的信息,请进入主菜单录入你的信息!
c=head1;
你的可选课程编号:
while(c!
for(t=0,i=0;
i++)
if(c->
num1==s->
nelenum[i])t=1;
if(t==0&
(c->
nelepeo!
=c->
Melepeo))
%d\n"
c->
j++;
c=c->
if(j==0)
*
你已选完所有课程,无法再多选!
选课(y/n):
e=getchar();
while(e=='
y'
$
elect(s);
继续选课(y/n):
voidback(structstudent*p)
structcouse*p1;
<
intnum1,i,j;
请输入你要退掉的课程编号:
=num1)p1=p1->
p->
=num1;
for(j=i;
nelenum[j]!
j++)p->
nelenum[j]=p->
nelenum[j+1];
nelenum[--j]=0;
nelepeo)--;
退课成功!
voidhcheak()
charc;
structcouse*p0;
structstudent*p;
intnum2,i,f=0;
请输入学号:
p=head2;
p!
=NULL)p=p->
if(p==NULL)
不存在你的信息,请回主菜单录入信息:
已选课程编号:
if(p->
nelenum[0]==0)
你还没选课!
i++)
p->
nelenum[i]);
p0=head1;
while(p0->
=p->
nelenum[i])p0=p0->
f=f+p0->
score;
总学分:
f);
/
是否进行退课(y/n)"
c=getchar();
while(c=='
back(p);
继续退课(y/n)"
(p->
nelen)--;
voidelective()
\t\t\t学生选课\n"
1.查询可选课程\n"
2.查询已选课程\n"
请输入(1~3):
cheak();
hcheak();
voidlistc()
课程编号课程名称学分课程已选人数课程人数上限\n"
while(p!
%-8d%10s%6d%8d%12d\n"
num1,p->
name1,p->
score,p->
nelepeo,p->
p=p->
voidlists()
学生学号学生姓名已选课程数量\n"
%-4d%10s%6d\n"
num2,p->
name2,p->
nelen);
voidintoc()
charfilepath[30];
输入课程信息要保存的文件路径:
w"
\n保存失败!
fprintf(fp,"
%d%s%d%d%d\n"
fclose(fp);
课程信息已保存在%s中!
voidintos()
输入学生信息要保存的文件路径:
fwrite(p,sizeof(structstudent),1,fp);
学生信息已保存在%s中!
voidinto()
1.存储课程信息\n"
2.存储学生信息\n"
请输入(1~3)\n"
intoc();
intos();
voidstore()
\t\t系统信息查看及存储\n"
1.查看课程信息\n"
2.查看学生信息\n"
3.存储信息\n"
4.返回主菜单\n"
请输入(1~4):
listc();
lists();
into();
case(4):
intmain()
start:
\n\t\t\t欢迎使用学生选课系统!
菜单:
1.录入课程信息\n"
2.课程管理\n"
3.录入学生信息\n"
4.学生信息管理\n"
5.学生选课\n"
6.系统信息查看及存储\n"
7.退出系统\n"
\n请输入菜单选项(1~7):
if(i<
1||i>
7)
输入错误,请重输:
gotostart;
system("
cls"
inputc();
managementc();
sy
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 学生 选课 系统 代码