- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章基于C语言实现学生选课系统由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
鉴于C语言实现的通讯录,为了巩固C语言的基础知识,试着写一个简单的学生选课系统.
思路比较简单:
1.回滚显示各种提示信息或操作信息 。
2.链表操作.
代码中有管理员部分功能没有实现,学生和老师的功能基本实现,但有待加固,如果初学者可是试着去完善一下。 还可以将老师,学生的信息输出到文件文本中,本代码中没有实现,但并不是很难.
代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
|
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/* 总链表——存放所有信息 */
typedef
struct
Sum_Node
{
/* 学生信息 */
char
stuNo[20][20];
char
stuName[20][20];
char
stuSex[20][20];
/* 课程信息 */
char
CourseNum[20];
char
CourseName[20];
char
CourseTeacher[20];
struct
Sum_Node *next;
}TotalNode;
/* 链表管理员——暂时不需要 */
/*typedef struct Node
{
char Num[20];
char Name[20];
char Sex[10];
struct Node *next;
}Manager_Node;*/
char
studentAccount[20];
char
studentPassword[20];
char
teacherAccount[20];
char
teacherPassword[20];
char
managerAccount[20];
char
managerPassword[20];
/* 定义结构体指针 */
TotalNode *pTeacher;
TotalNode *pStudent;
/* 函数的声明 */
void
checkPerson_Msg(TotalNode *phead,
int
n);
void
CreateTeacherNode(TotalNode *head);
/* 学生信息的输出-链表 */
void
OutStudentNode(TotalNode *head,
char
*Account)
{
TotalNode *p;
int
num=0;
int
i,j;
int
flag=0;
char
Account_random[20]=
""
;
pStudent=pTeacher;
// 学生和老师用的链表是同一个
p=pStudent;
puts
(
"******所选课程信息******"
);
puts
(
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"
);
if
(pStudent==NULL)
{
puts
(
"没有数据!"
);
puts
(
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"
);
return
;
}
printf
(
"请输入所要查询人的姓名:"
);
gets
(Account_random);
// 获取所要查询的学生姓名
if
(0 == Account_random[0])
{
gets
(Account_random);
}
while
(p!=NULL)
{
for
(j=0;j<20;j++)
{
if
(0 ==
strcmp
(p->stuName[j],Account_random))
{
printf
(
"课程代码:%s\t"
,p->CourseNum);
printf
(
"课程名称:%s\t"
,p->CourseName);
printf
(
"课程老师:%s\t"
,p->CourseTeacher);
for
(i=0;i<20;i++)
{
if
(p->stuNo[i][0]!=
'\0'
)
{
num++;
}
}
printf
(
"选课学生:%d\t"
,num);
num=0;
// 清0操作
putchar
(
'\n'
);
flag=1;
}
}
p=p->next;
}
if
(0 == flag)
{
puts
(
"没有该学生选课信息!!!!"
);
}
puts
(
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"
);
putchar
(
'\n'
);
}
/* 学生信息的插入-链表 */
void
InsertStudentNode(TotalNode *head,
char
*Account)
{
TotalNode *p;
int
i;
char
courseCode[20]=
""
;
pStudent=pTeacher;
// 学生和老师用的链表是同一个,都是链表头
p=pStudent;
if
(p==NULL)
{
puts
(
"等待教师录入选课信息,请下次再进行选择!!"
);
return
;
}
printf
(
"【请输入正确的课程代码】"
);
gets
(courseCode);
if
(0 == courseCode[0])
{
gets
(courseCode);
}
while
(p!=NULL)
{
if
(0 ==
strcmp
(p->CourseNum, courseCode))
{
for
(i=0;i<20;i++)
{
if
(p->stuNo[i][0] ==
'\0'
)
{
printf
(
"请输入学号:"
);
gets
(p->stuNo[i]);
printf
(
"请输入姓名:"
);
gets
(p->stuName[i]);
printf
(
"请输入性别:"
);
gets
(p->stuSex[i]);
puts
(
"选课成功!!!!"
);
return
;
}
}
}
p=p->next;
}
puts
(
"$$$$$$选课失败,请重新选择$$$$$$"
);
}
/* 删除所选课程 */
void
DeleteStudentNode(TotalNode *head,
char
*Account)
{
char
coursNo[20]=
""
;
// 课程代码
char
student[20]=
""
;
// 学生姓名
TotalNode *p;
int
i;
int
flag=0;
pStudent=pTeacher;
// 学生和老师用的链表是同一个,都是链表头
p=pStudent;
if
(pStudent==NULL)
{
puts
(
"没选该课程,删除失败!!!!"
);
return
;
}
printf
(
"【输入学生姓名】"
);
gets
(student);
if
(0 == student[0])
{
gets
(student);
}
printf
(
"【请输入删除的课程代码】"
);
gets
(coursNo);
if
(0 == coursNo[0])
{
gets
(coursNo);
}
while
(p!=NULL)
{
if
(0==
strcmp
(p->CourseNum,coursNo))
// 查询所要删除的课程代码
{
for
(i=0;i<20;i++)
{
if
(0==
strcmp
(p->stuName[i],student))
{
/* 初始化清0操作 */
p->stuNo[i][0]=
'\0'
;
p->stuName[i][0]=
'\0'
;
p->stuSex[i][0]=
'\0'
;
puts
(
"删除成功!!!!"
);
flag=1;
// 删除标志位
}
}
}
p=p->next;
}
if
(0 == flag)
// 如果删除成功标志位置1
{
puts
(
"删除失败!!!!"
);
}
}
/* 教师信息的输出-链表 */
void
OutTeacherNode(TotalNode *head)
{
TotalNode *p;
int
num=0;
int
i;
p=pTeacher;
puts
(
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"
);
if
(pTeacher==NULL)
{
puts
(
"没有数据!"
);
puts
(
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"
);
return
;
}
while
(p!=NULL)
{
printf
(
"课程代码:%s\t"
,p->CourseNum);
printf
(
"课程名称:%s\t"
,p->CourseName);
printf
(
"课程老师:%s\t"
,p->CourseTeacher);
for
(i=0;i<20;i++)
{
if
(p->stuNo[i][0]!=
'\0'
)
{
num++;
}
}
printf
(
"选课学生:%d\t"
,num);
num=0;
// 清0操作
putchar
(
'\n'
);
p=p->next;
}
puts
(
"++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"
);
putchar
(
'\n'
);
}
/* 教师信息的插入-链表 */
void
InsertTeacherNode(TotalNode *head)
{
TotalNode *p;
TotalNode *q;
int
i;
p=pTeacher;
// 教师链表的头
if
(pTeacher==NULL)
{
CreateTeacherNode(head);
puts
(
"添加成功!"
);
return
;
}
while
(p!=NULL)
{
if
(p->next == NULL)
{
q=(TotalNode *)
malloc
(
sizeof
(TotalNode));
p->next=q;
q->next=NULL;
for
(i=0;i<20;i++)
{
q->stuNo[i][0]=
'\0'
;
}
printf
(
"请输入课程代码:"
);
gets
(q->CourseNum);
if
(0 == *q->CourseNum)
{
gets
(q->CourseNum);
}
printf
(
"请输入课程名称:"
);
gets
(q->CourseName);
printf
(
"请输入课程教师:"
);
gets
(q->CourseTeacher);
puts
(
"添加成功!"
);
break
;
}
p=p->next;
}
//pTeacher=head;
}
/* 教师信息的插入-链表 */
void
CreateTeacherNode(TotalNode *head)
{
int
i;
pTeacher=(TotalNode *)
malloc
(
sizeof
(TotalNode));
pTeacher->next=NULL;
for
(i=0;i<20;i++)
{
pTeacher->stuNo[i][0]=
'\0'
;
}
printf
(
"请输入课程代码:"
);
gets
(pTeacher->CourseNum);
if
(0 == *pTeacher->CourseNum)
{
gets
(pTeacher->CourseNum);
}
printf
(
"请输入课程名称:"
);
gets
(pTeacher->CourseName);
printf
(
"请输入课程教师:"
);
gets
(pTeacher->CourseTeacher);
//pTeacher=head;
}
/* 删除指定数据 */
void
DeleteTeacherNode(TotalNode *phead)
{
char
coursNo[20]=
""
;
// 课程代码
TotalNode *p;
TotalNode *s;
p=pTeacher;
// 教师链表的头
s=pTeacher;
if
(NULL==pTeacher)
{
puts
(
"没有课程信息!!!!"
);
return
;
}
printf
(
"【请输入删除的课程代码】"
);
gets
(coursNo);
if
(0 == coursNo[0])
{
gets
(coursNo);
}
if
(0 ==
strcmp
(p->CourseNum,coursNo))
{
pTeacher=p->next;
puts
(
"删除成功!!"
);
return
;
}
while
(p != NULL)
{
if
(0 ==
strcmp
(p->CourseNum,coursNo))
{
s->next=p->next;
puts
(
"删除成功!!"
);
return
;
}
s=p;
p=p->next;
}
}
/* 功能显示 */
void
display(TotalNode *phead)
{
int
n;
while
(1)
{
puts
(
"=========请选择登录页面========="
);
puts
(
"[1]学生登录"
);
puts
(
"[2]教师登录"
);
puts
(
"[3]管理员登录"
);
puts
(
"[4]退出系统"
);
while
(1)
// 循环检查输入的值是否正确
{
printf
(
"【请选择】"
);
scanf
(
"%d"
,&n);
if
(n>4 || n<1)
{
puts
(
"输入有误,请选择正确的选项:"
);
continue
;
// 输入不正确,重新输入
}
else
{
break
;
// 输入正确,退出循环
}
}
if
( 1 == n )
// 学生登录系统
{
puts
(
"=========欢迎登录学生系统========="
);
printf
(
"请输入账号和密码\n"
);
checkPerson_Msg(phead,1);
}
if
( 2 == n )
// 老师登录系统
{
puts
(
"=========欢迎登录教师系统========="
);
printf
(
"请输入账号和密码\n"
);
checkPerson_Msg(phead,2);
}
if
( 3 == n )
// 管理员登录系统
{
puts
(
"=========欢迎登录管理员系统========="
);
printf
(
"请输入账号和密码\n"
);
checkPerson_Msg(phead,3);
}
if
( 4 == n )
// 退出系统
{
puts
(
"@@@@@@@@@欢迎下次登录,再见!!!@@@@@@@@@"
);
exit
(0);
}
}
}
/* 学生登录后的操作,查询、修改 */
void
Student_Mng(TotalNode *phead,
char
*Account,
int
n)
{
switch
(n)
{
case
1:
// 查询
OutStudentNode(phead,Account);
break
;
case
2:
// 添加
InsertStudentNode(phead,Account);
break
;
case
3:
// 删除
DeleteStudentNode(phead,Account);
break
;
case
4: ;
// 返回主页面,上层已经实现,此处不需要考虑
break
;
default
:
puts
(
"异常!"
);
break
;
}
}
/* 教师登录后的操作,查询、修改 */
void
Teacher_Mng(TotalNode *phead,
char
*Account,
int
n)
{
switch
(n)
{
case
1:
// 查询学生选课情况
OutTeacherNode(phead);
break
;
case
2:
// 添加和删除课程信息
InsertTeacherNode(phead);
break
;
case
3:
DeleteTeacherNode(phead);
break
;
case
4:
break
;
// 上层实现其功能
default
:
puts
(
"异常!"
);
break
;
}
}
/* 管理员登录后的操作,查询、修改 */
void
Manager_Mng(
char
*Account,
int
n)
{
switch
(n)
{
case
1:
break
;
case
2:
break
;
case
3:
break
;
default
:
puts
(
"异常!"
);
break
;
}
}
/* 显示各功能登录后的信息 */
void
display_Detailed(TotalNode *phead ,
char
*Account,
int
n)
{
int
in;
switch
(n)
{
case
1:
while
(1)
{
printf
(
"=========欢迎%s同学=========\n"
,Account);
puts
(
"[1]查询已选课程"
);
// 查询自己所选的所有课程包括:课程代码、课程名称、任课老师
puts
(
"[2]添加课程"
);
// 增加所选课程
puts
(
"[3]删除所选课程"
);
// 删除所选课程
puts
(
"[4]返回主页面"
);
printf
(
"【请选择】"
);
scanf
(
"%d"
,&in);
if
(4 == in)
{
return
;
// 返回上层登录页面
}
Student_Mng(pStudent,Account, in);
//puts("[4]");
}
break
;
case
2:
while
(1)
{
printf
(
"=========欢迎%s老师=========\n"
,Account);
puts
(
"[1]查询学生选课信息"
);
//
puts
(
"[2]添加老师课程信息"
);
//
puts
(
"[3]删除老师课程信息"
);
//
puts
(
"[4]返回主页面"
);
printf
(
"【请选择】"
);
scanf
(
"%d"
,&in);
if
(4 == in)
{
return
;
// 返回上层登录页面
}
Teacher_Mng(pTeacher,Account, in);
}
//puts("[4]");
break
;
case
3:
printf
(
"=========欢迎%s同志=========\n"
,Account);
puts
(
"[1]查询学生所选课程信息"
);
puts
(
"[2]修改选课信息"
);
puts
(
"[3]返回主页面"
);
scanf
(
"%d"
,&in);
Manager_Mng(Account, in);
//puts("[4]");
break
;
default
:
puts
(
"异常!"
);
break
;
}
}
/* 验证账号密码 */
void
checkAccountandPassword(TotalNode *phead ,
char
*Account,
char
*Password,
int
n)
{
while
(1)
{
gets
(Account);
/**/
if
(0 ==
strcmp
(Account,
"wantin"
))
{
while
(1)
{
printf
(
"请输入密码:"
);
gets
(Password);
if
(0 ==
strcmp
(Password,
"123456"
))
{
display_Detailed(phead,Account, n);
return
;
}
}
}
else
{
printf
(
"请输入账号:"
);
}
}
}
/* 校验学生、教师、管理员的账号 密码 */
void
checkPerson_Msg(TotalNode *phead ,
int
n)
{
switch
(n)
{
case
1:
// 学生登录 char studentAccount[20]; char studentPassword[20];
checkAccountandPassword(phead, studentAccount,studentPassword,n);
break
;
case
2:
// 教师登录 char teacherAccount[20]; char teacherPassword[20];
checkAccountandPassword(phead, teacherAccount,teacherPassword,n);
break
;
case
3:
// 管理员登录 char managerAccount[20]; char managerPassword[20];
checkAccountandPassword(phead, managerAccount,managerPassword,n);
break
;
default
:
puts
(
"异常!"
);
break
;
}
}
/* */
void
main()
{
TotalNode *phead=NULL;
display(phead);
}
|
大家可以根据下面的操作来帮助读懂这段代码.
操作结果如下:
=========请选择登录页面========= [1]学生登录 [2]教师登录 [3]管理员登录 [4]退出系统 【请选择】2 =========欢迎登录教师系统========= 请输入账号和密码 请输入账号:wantin 请输入密码:123456 =========欢迎wantin老师========= [1]查询学生选课信息 [2]添加老师课程信息 [3]删除老师课程信息 [4]返回主页面 【请选择】2 请输入课程代码:123 请输入课程名称:C语言 请输入课程教师:王艇 添加成功! =========欢迎wantin老师========= [1]查询学生选课信息 [2]添加老师课程信息 [3]删除老师课程信息 [4]返回主页面 【请选择】2 请输入课程代码:456 请输入课程名称:Java 请输入课程教师:王艇 添加成功! =========欢迎wantin老师========= [1]查询学生选课信息 [2]添加老师课程信息 [3]删除老师课程信息 [4]返回主页面 【请选择】2 请输入课程代码:789 请输入课程名称:PHP 请输入课程教师:王艇 添加成功! =========欢迎wantin老师========= [1]查询学生选课信息 [2]添加老师课程信息 [3]删除老师课程信息 [4]返回主页面 【请选择】1 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 课程代码:123 课程名称:C语言 课程老师:王艇 选课学生:0 课程代码:456 课程名称:Java 课程老师:王艇 选课学生:0 课程代码:789 课程名称:PHP 课程老师:王艇 选课学生:0 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 。
=========欢迎wantin老师========= [1]查询学生选课信息 [2]添加老师课程信息 [3]删除老师课程信息 [4]返回主页面 【请选择】4 =========请选择登录页面========= [1]学生登录 [2]教师登录 [3]管理员登录 [4]退出系统 【请选择】1 =========欢迎登录学生系统========= 请输入账号和密码 请输入账号:wantin 请输入密码:123456 =========欢迎wantin同学========= [1]查询已选课程 [2]添加课程 [3]删除所选课程 [4]返回主页面 【请选择】1 ******所选课程信息****** ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 请输入所要查询人的姓名:王艇 没有该学生选课信息!!!! ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 。
=========欢迎wantin同学========= [1]查询已选课程 [2]添加课程 [3]删除所选课程 [4]返回主页面 【请选择】3 【输入学生姓名】王艇 【请输入删除的课程代码】123 删除失败!!!! =========欢迎wantin同学========= [1]查询已选课程 [2]添加课程 [3]删除所选课程 [4]返回主页面 【请选择】2 【请输入正确的课程代码】123 请输入学号:110 请输入姓名:王艇 请输入性别:男 选课成功!!!! =========欢迎wantin同学========= [1]查询已选课程 [2]添加课程 [3]删除所选课程 [4]返回主页面 【请选择】1 ******所选课程信息****** ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 请输入所要查询人的姓名:王艇 课程代码:123 课程名称:C语言 课程老师:王艇 选课学生:1 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 。
=========欢迎wantin同学========= [1]查询已选课程 [2]添加课程 [3]删除所选课程 [4]返回主页面 【请选择】4 =========请选择登录页面========= [1]学生登录 [2]教师登录 [3]管理员登录 [4]退出系统 【请选择】2 =========欢迎登录教师系统========= 请输入账号和密码 请输入账号:wantin 请输入密码:123456 =========欢迎wantin老师========= [1]查询学生选课信息 [2]添加老师课程信息 [3]删除老师课程信息 [4]返回主页面 【请选择】1 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 课程代码:123 课程名称:C语言 课程老师:王艇 选课学生:1 课程代码:456 课程名称:Java 课程老师:王艇 选课学生:0 课程代码:789 课程名称:PHP 课程老师:王艇 选课学生:0 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 。
=========欢迎wantin老师========= [1]查询学生选课信息 [2]添加老师课程信息 [3]删除老师课程信息 [4]返回主页面 【请选择】4 =========请选择登录页面========= [1]学生登录 [2]教师登录 [3]管理员登录 [4]退出系统 【请选择】1 =========欢迎登录学生系统========= 请输入账号和密码 请输入账号:wantin 请输入密码:123456 =========欢迎wantin同学========= [1]查询已选课程 [2]添加课程 [3]删除所选课程 [4]返回主页面 【请选择】2 【请输入正确的课程代码】456 请输入学号:110 请输入姓名:王艇 请输入性别:男 选课成功!!!! =========欢迎wantin同学========= [1]查询已选课程 [2]添加课程 [3]删除所选课程 [4]返回主页面 【请选择】1 ******所选课程信息****** ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 请输入所要查询人的姓名:王艇 课程代码:123 课程名称:C语言 课程老师:王艇 选课学生:1 课程代码:456 课程名称:Java 课程老师:王艇 选课学生:1 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 。
=========欢迎wantin同学========= [1]查询已选课程 [2]添加课程 [3]删除所选课程 [4]返回主页面 【请选择】2 【请输入正确的课程代码】123 请输入学号:112 请输入姓名:王五 请输入性别:男 选课成功!!!! =========欢迎wantin同学========= [1]查询已选课程 [2]添加课程 [3]删除所选课程 [4]返回主页面 【请选择】1 ******所选课程信息****** ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 请输入所要查询人的姓名:王艇 课程代码:123 课程名称:C语言 课程老师:王艇 选课学生:2 课程代码:456 课程名称:Java 课程老师:王艇 选课学生:1 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 。
=========欢迎wantin同学========= [1]查询已选课程 [2]添加课程 [3]删除所选课程 [4]返回主页面 【请选择】1 ******所选课程信息****** ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 请输入所要查询人的姓名:王五 课程代码:123 课程名称:C语言 课程老师:王艇 选课学生:2 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 。
=========欢迎wantin同学========= [1]查询已选课程 [2]添加课程 [3]删除所选课程 [4]返回主页面 【请选择】4 =========请选择登录页面========= [1]学生登录 [2]教师登录 [3]管理员登录 [4]退出系统 【请选择】2 =========欢迎登录教师系统========= 请输入账号和密码 请输入账号:wantin 请输入密码:123456 =========欢迎wantin老师========= [1]查询学生选课信息 [2]添加老师课程信息 [3]删除老师课程信息 [4]返回主页面 【请选择】1 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 课程代码:123 课程名称:C语言 课程老师:王艇 选课学生:2 课程代码:456 课程名称:Java 课程老师:王艇 选课学生:1 课程代码:789 课程名称:PHP 课程老师:王艇 选课学生:0 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 。
=========欢迎wantin老师========= [1]查询学生选课信息 [2]添加老师课程信息 [3]删除老师课程信息 [4]返回主页面 【请选择】 。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:https://blog.csdn.net/XiaoCaiDaYong/article/details/68486910 。
最后此篇关于基于C语言实现学生选课系统的文章就讲到这里了,如果你想了解更多关于基于C语言实现学生选课系统的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
在parser.h中: typedef enum _SEX {MALE = 'M', FEMALE = 'F', OTHER = 'O'} SEX; struct course { char gra
共有三个实体: School, teacher and student 有一些规则: 一个学生只能属于一位老师 一名学生只能属于一所学校 一名教师可以属于一所或多所学校 这意味着我的表中有这些关系:
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 2 年前。 Improve this qu
我正在构建一个涉及学生和顾问的 Web 应用程序。学生将选择他的独立学习,顾问将对其进行监督。我正在努力为我的程序找到正确的关系。 基本上我的应用程序中的参与者是。 a Student can sel
支持Python的IDE有IPython、Aptana Studio(在Eclipse的基础上加插件集改的)、PyCharm(由 JetBrains 打造的一款 Python IDE,支持 macO
我对 sql 和 Stack Overflow 非常陌生。我希望有人可以帮助我解决这个问题。我的查询应该显示销售额超过 200,000 美元的类别的总销售额和已售商品总数。我已经研究这个查询一个小时了
public class Menu extends Activity { /** Called when the activity is first created. */ public
当我在 R 中运行学生 t-分布时,我得到以下结果: > pt(1.849, 2, lower.tail=FALSE) [1] 0.1028493 当我运行 Apache Commons Math 库
我的机器人实验室正在寻找程序员来从事我们目前的一些项目。 我们确定了要求(主要是 C++ 和 openGL 和 3D 经验),但由于明显的资金限制,我们无力聘请优秀的开发人员。相反,我们将满足于有才华
我正在努力完成一个使用替换密码来编码和解码 txt 文件的程序。经过相当多的工作,我的程序几乎完成了。该程序首先询问用户是否要对文件进行编码或解码。回答这个问题后,程序会提示用户输入正在输入的文件的名
我是一个刚开始编程的菜鸟,我想知道为什么我会收到一条错误消息:非静态数据成员“Lavirint::n”的使用无效? class Lavirint{ private: int n, m;
该项目的目标是创建四个类:Student 类、GradStudent 类、Manager 类和 GUI 类。 GUI 中有两个单选按钮:一个用于学生,一个用于研究生。根据选择的对象,Manager 类
我正在尝试向学生、教师和家长 Activity 实现抽屉导航 Activity ,但它不起作用,请指导我如何在登录后向不同角色的用户添加抽屉导航。 最佳答案 您需要在 中自定义布局像这样:
我是 JS 的新手,甚至是 Jquery 和 fullcalendar 的新手。我创建了一个单独在页面上运行良好的日历。我正在尝试将此代码与另一个页面结合使用,但我无法让日历呈现。 首先我包含一些文件
我正在开发一个简单的 Linux Shell,它可以 fork() 并调用 execvp(),但我最近添加了不需要 fork() 的“内置函数”。 这是执行处理: if (strcmp(cmd
我在使用分配给我的这个初学者 Java 程序时遇到了麻烦,我是 Java 的新手,而且我在使用这个特定程序时遇到了很多麻烦。这些是说明: Your program should prompt user
在下面的代码块中,有几个(故意的)错误,我的任务是找到它们并解释这些错误是否会导致编译代码时出现问题,或者至少会导致一些逻辑问题。 public class Person { private St
我想加载一个文件,将其内容拆分为数组,然后将类应用到内容。 class Student def initialize( name, grade ) @name = name
我有 3 个实体:导师、学生、类(class) 导师教授许多类(class) 学生可以被分配到由多名导师教授的许多类(class) 导师和学生需要能够登录系统 我想使用下表来表示此设计: users
我想弄清楚这里的填充是否可调 这是 HTML: {block:IfHeaderImage} {/block:IfHeaderImage} {block:IfNot
我是一名优秀的程序员,十分优秀!