-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathxueshengxinxi.txt
511 lines (459 loc) · 14.3 KB
/
xueshengxinxi.txt
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
#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>
#include <string.h>
#define LEN sizeof(STD)
typedef struct student {
char xh[12]; /*学号*/
char xm[12]; /*姓名*/
float sxcj; /*数学成绩*/
float cxsj; /*程序设计成绩*/
float zf; /*总分*/
struct student *next; /*指向下条记录*/
}STD;
int NUM = 0; /* 定义全局变量,统计学生人数 */
STD *head = NULL;
void mainmenu(); /* 主菜单 */
void record(); /* 写入学生信息 */
void insert( struct student *p ); /* 插入学生信息 */
void print( struct student *p ); /* 打印信息 */
void display(); /* 查看所有学生信息 */
void query(); /* 创建查询 */
void query_by_num(); /*按学号查询 */
void query_by_name(); /*按姓名查询 */
void query_by_sxcj(); /*按数学成绩查询 */
void query_by_cxsj(); /*按程序设计成绩查询 */
void query_by_zf(); /*按总分查询 */
void readData(); /* 读取数据 */
void writeData(); /* 写入数据 */
void freeAll(); /* 释放结点 */
void del(); /*删除学生信息 */
void change(); /* 修改学生信息 */
void devise( struct student *p );
int main(void)
{
mainmenu();
}
/* 主菜单 */
void mainmenu()
{
int choice;
readData();
do
{
printf( "\t\t\t +--------------------+\n" );
printf( "\t\t\t | 学生信息管理系统 |\n" );
printf( "\t\t\t | [1]--创建学生信息 |\n" );
printf( "\t\t\t | [2]--浏览学生信息 |\n" );
printf( "\t\t\t | [3]--查询学生信息 |\n" );
printf( "\t\t\t | [4]--删除学生信息 |\n" );
printf( "\t\t\t | [5]--修改学生信息 |\n" );
printf( "\t\t\t | [6]--退出系统 |\n" );
printf( "\t\t\t +--------------------+\n" );
printf( "请输入操作选项:" );
scanf( "%d", &choice );
switch ( choice )
{
case 1:
record(); /* 读入学生信息 */
break;
case 2:
display(); /* 查看学生信息 */
break;
case 3:
query(); /* 查询学生信息 */
break;
case 4:
del(); /*删除学生信息 */
break;
case 5:
change(); /* 修改学生信息 */
break;
default:
printf( "无效选项!\n" );
break;
case 6:
writeData(); /* 把学生信息写入文件中 */
freeAll(); /* 释放所有结点 */
exit( 0 ); /* 退出 */
}
}
while ( choice != 6 );
}
/* 录入学生信息,每次只录入一个学生信息 */
void record()
{
struct student *p0;
p0 = (STD *) malloc( LEN );
printf( "请输入学生的学号:" );
scanf( "%s", &p0->xh );
printf( "请输入学生的姓名:" );
scanf( "%s", p0->xm );
printf( "请输入学生的数学成绩:" );
scanf( "%f", &p0->sxcj );
printf( "请输入学生的程序设计成绩:" );
scanf( "%f", &p0->cxsj );
p0->zf = p0->sxcj + p0->cxsj;
insert( p0 ); /* 每次录入一个学生信息后将其插入链表中 */
printf( "该学生的信息为:\n" );
printf( "学号\t姓名\t数学\t程序\t总分\n" );
print( p0 ); /* 每次录入一个学生信息后输出其信息 */
}
/* 插入学生信息 */
void insert( STD *stu )
{
STD *p0, *p1, *p2;
p1 = head;
p0 = stu;
if ( head == NULL )
{
head = p0;
p0->next = NULL;
}else {
while ( (p0->xh > p1->xh) && (p1->next != NULL) )
{
p2 = p1;
p1 = p1->next;
}
if ( p0->xh <= p1->xh )
{
if ( head == p1 )
head = p0;
else
p2->next = p0;
p0->next = p1;
}else {
p1->next = p0;
p0->next = NULL;
}
}
NUM++; /* 累加统计学生人数 */
}
/* 打印信息 */
void print( struct student *p )
{
printf( "%s\t%s\t%-5.2f\t%-5.2f\t%-5.2f\n", p->xh, p->xm, p->sxcj, p->cxsj, p->zf );
}
/* 查看学生信息 */
void display()
{
struct student *p;
printf( "学生总人数:%d\n", NUM );
p = head;
if ( head != NULL )
{
printf( "学号\t姓名\t数学\t程序\t总分\n" );
do
{
print( p );
p = p->next;
}
while ( p != NULL );
}
printf( "\n" );
}
/* 查询学生信息 */
void query()
{
int choice;
do
{
printf( "+---------------------+\n" );
printf( "|[1]--按学号查询 |\n" );
printf( "|[2]--按姓名查询 |\n" );
printf( "|[3]--数学成绩查询 |\n" );
printf( "|[4]--程序设计成绩查询|\n" );
printf( "|[5]--总分查询 |\n" );
printf( "|[6]--返回主菜单 |\n" );
printf( "+---------------------+\n" );
printf( "请输入操作选项:" );
scanf( "%d", &choice );
switch ( choice )
{
case 1:
query_by_num();
break;
case 2:
query_by_name();
break;
case 3:
query_by_sxcj();
break;
case 4:
query_by_cxsj();
case 5:
query_by_zf();
default:
printf( "操作选项错误!\n" );
break;
case 6:
return;
}
}
while ( choice != 6 );
}
/*按学号查询学生信息 */
void query_by_num()
{
char num[10];
struct student *p1;
printf( "请输入学生的学号:" );
scanf( "%s", num );
if ( head == NULL )
{
printf( "没有学生信息!\n" );
return;
}
p1 = head;
while ( strcmp( num, p1->xh ) != 0 && p1->next != NULL )
p1 = p1->next;
if ( strcmp( num, p1->xh ) == 0 )
{
printf( "学号\t姓名\t数学\t程序\t总分\n" );
print( p1 );
}else
printf( "没有找到该学生信息!\n" );
}
/*按姓名查询学生信息 */
void query_by_name()
{
char name[20];
STD *p1;
printf( "请输入学生的姓名:" );
scanf( "%s", name );
if ( head == NULL )
{
printf( "没有学生信息!\n" );
return;
}
p1 = head;
while ( strcmp( name, p1->xm ) != 0 && p1->next != NULL )
p1 = p1->next;
if ( !strcmp( name, p1->xm ) )
{
printf( "学号\t姓名\t数学\t程序\t总分\n" );
print( p1 );
}else
printf( "没有找到该学生信息!\n" );
}
/*按数学成绩查询 */
void query_by_sxcj()
{
float sxcj;
STD *p1;
printf( "请输入学生的数学成绩:" );
scanf( "%f", &sxcj );
if ( head == NULL )
{
printf( "没有学生信息!\n" );
return;
}
p1 = head;
while ( sxcj != p1->sxcj && p1->next != NULL )
p1 = p1->next;
if ( sxcj == p1->sxcj )
{
printf( "学号\t姓名\t数学\t程序\t总分\n" );
print( p1 );
}else
printf( "没有找到该学生信息!\n" );
}
/*按程序设计成绩查询 */
void query_by_cxsj()
{
float cxsj;
STD *p1;
printf( "请输入学生的程序设计成绩:" );
scanf( "%f", &cxsj );
if ( head == NULL )
{
printf( "没有学生信息!\n" );
return;
}
p1 = head;
while ( cxsj != p1->cxsj && p1->next != NULL )
p1 = p1->next;
if ( cxsj == p1->cxsj )
{
printf( "学号\t姓名\t数学\t程序\t总分\n" );
print( p1 );
}else
printf( "没有找到该学生信息!\n" );
}
/*按总分查询 */
void query_by_zf()
{
float zf;
STD *p1;
printf( "请输入学生的总分成绩:" );
scanf( "%f", &zf );
if ( head == NULL )
{
printf( "没有学生信息!\n" );
return;
}
p1 = head;
while ( zf != p1->zf && p1->next != NULL )
p1 = p1->next;
if ( zf == p1->zf )
{
printf( "学号\t姓名\t数学\t程序\t总分\n" );
print( p1 );
}else
printf( "没有找到该学生信息!\n" );
}
/*删除学生信息 */
void del()
{
struct student *p1, *p2;
char num[12];
if ( head == NULL )
{
printf( "没有学生信息!\n" );
return;
}
printf( "请输入您要删除的学生的学号:" );
scanf( "%s", num );
p1 = head;
while ( strcmp( num, p1->xh ) != 0 && p1->next != NULL )
{
p2 = p1;
p1 = p1->next;
}
if ( strcmp( num, p1->xh ) == 0 )
{
if ( p1 == head )
head = p1->next;
else
p2->next = p1->next;
free( p1 );
NUM--;
}else
printf( "没有该学生的信息!\n" );
}
/* 修改学生信息 */
void change()
{
STD *p1, *p2;
char num[12];
if ( head == NULL )
{
printf( "没有学生的信息!\n" );
return;
}
printf( "请输入您要修改的学生的学号:" );
scanf( "%s", num );
p1 = head;
while ( strcmp( num, p1->xh ) != 0 && p1->next != NULL )
{
p2 = p1;
p1 = p1->next;
}
if ( strcmp( num, p1->xh ) == 0 )
devise( p1 );
else
printf( "没有该学生的信息!\n" );
}
/* 修改学生信息 */
void devise( struct student *p )
{
int choice;
do
{
printf( "+------------------------------+\n" );
printf( "|请选择您要修改的学生的信息内容|\n" );
printf( "|[1]--学号 |\n" );
printf( "|[2]--姓名 |\n" );
printf( "|[3]--数学成绩 |\n" );
printf( "|[4]--程序设计成绩 |\n" );
printf( "|[5]--总分 |\n" );
printf( "|[6]--取消 |\n" );
printf( "+------------------------------+\n" );
printf( "请输入操作选项:" );
scanf( "%d", &choice );
switch ( choice )
{
case 1:
printf( "请输入新学号:" );
scanf( "%s", p->xm );
break;
case 2:
printf( "请输入新姓名:" );
scanf( "%s", p->xm );
break;
case 3:
printf( "请输入新的数学成绩:" );
scanf( "%f", p->sxcj );
break;
case 4:
printf( "请输入新的程序设计成绩:" );
scanf( "%f", p->cxsj );
break;
case 5:
printf( "请输入新的总分:" );
scanf( "%f", p->zf );
break;
case 6:
return;
default:
printf( "选项错误!\n" );
break;
}
}
while ( choice != 6 );
}
/* 读取文件 */
void readData()
{
FILE *fp;
STD *p1, *p2;
fp = fopen( "students.txt", "r" ); /* 打开文件 */
if ( !fp )
{
printf( "文件打开错误!\n" );
return;
}
fscanf( fp, "%d\n", &NUM );
head = p1 = p2 = (STD *) malloc( LEN );
fscanf( fp, "%s\t%s\t%f\t%f\t%f\n", p1->xh, p1->xm, &p1->sxcj, &p1->cxsj, &p1->zf ); /* */
while ( !feof( fp ) )
{
p1 = (struct student *) malloc( LEN );
fscanf( fp, "%s\t%s\t%f\t%f\t%f\n", p1->xh, p1->xm, &p1->sxcj, &p1->cxsj, &p1->zf );
p2->next = p1;
p2 = p1;
}
p2->next = NULL;
fclose( fp );
}
/* 写入文件 */
void writeData()
{
FILE * fp; /* 文件指针 */
STD *p;
fp = fopen( "students.txt", "w+" );
if ( !fp )
{
printf( "文件打开错误!\n" );
return;
}
fprintf( fp, "%d\n", NUM );
for ( p = head; p != NULL; p = p->next )
{
print(p);
fprintf( fp, "%s\t%s\t%f\t%f\t%f\n", p->xh, p->xm, p->sxcj, p->cxsj, p->zf );
}
fclose( fp );
}
/* 释放结点 */
void freeAll()
{
STD *p1, *p2;
p1 = p2 = head;
while ( p1 )
{
p2 = p1->next;
free( p1 );
p1 = p2;
}
}