C语言课程设计-学籍管理系统

  • 需求分析:

1.设计题目:学生学籍管理系统

2.系统功能需求分析:学生学籍管理是一项重要的任务,手工的操作已经不能适应现代化管理的需要,为了提高工作效率,利用计算机进行信息处理已经成为必然。开发功能完善及安全可靠的学籍管理系统可以大大方便学生学籍的管理和使用,及时、准确获取需要的信息,方便众多用户。

  • 概要设计:1、注册管理员用户

2、管理员用户登陆

3、1输入学生信息

4、2显示所有学生信息或根据条件查询学生信息

5、3修改学生信息

6、删除指定的学生信息

7、根据成绩进行排序

8、统计不及格学生人数并显示具体名单

9、将学生信息保存到磁盘文件

10、从磁盘文件读取数据

详细设计:

程序代码

#include<stdio.h> 
#include<string.h> 
#include<stdlib.h> 

typedef struct stud //学生信息结构 
{ 
long num; 
char name[20]; 
float score; 
}Stud; 

typedef struct node 
{ 
Stud student; 
struct node *next; 
}Node; 
Node *head=NULL; 
void read(void); 
void inser(long b); 
void print(); 
void find(long b); 
void searchname(char *s); 
Node * del(long n); 
void sort(int flag); 
void menu(); 

void main() 
{ 
char choose; 
int flag=1; 

while (flag) 
{ 
menu(); //调用功能菜单函数,显示菜单项。 
printf(" 请选择:"); 
choose=getchar(); 

switch(choose) 
{ 1 
case '1': read(); //调用建立链表的函数;输出链表信息; 
print(); 
printf("\nPress any key Continue "); 
//getchar(); 
getchar(); 
break; 
case '2': //调用按学号查找学生信息的函数;并输出查找结果信息; 
long c; 
printf("input the number you want to find:"); 
scanf("%ld",&c); 
find(c); 
printf("\nPress any key Continue."); 
getchar(); 
break; 
case '3': 
//调用按姓名查找学生信息的函数;并输出查找结果信息; 
char s[20]; 
printf("input the name you want to find:"); 
scanf("%s",s); 
searchname(s); 
printf("\n Press any key Continue."); 
getchar(); 
getchar(); 
break; 
case '4': 
//调用根据学号删除某个学生信息的函数;并输出删除后的链表信息; 
Node *h; 
long n; 
printf("input the number you want to delete:"); 
scanf("%ld",&n); 
h=del(n); 
if(h==NULL) printf("No find the student \n"); 
else print(); 
printf("\n Press any key Continue."); 
getchar(); 
getchar(); 
break; 
case '5': 
//调用插入新的学生信息的函数;并输出插入后的链表信息; 
long a; 
printf("input the number for the new:\n"); 
scanf("%ld",&a); 
inser(a); 2 
print(); 
printf("\n Press any key Continue."); 
getchar(); 
getchar(); 
break; 
case '6': 
//调用按分数降序排序输出的函数;并输出排序后的链表信息; 
sort(1); 
print(); 
sort(0); 
printf("\nPress any key Continue."); 
getchar(); 
getchar(); 
break; 
case '0': 
//结束程序运行! 
flag=0; 
printf("\n *** The End! ***\n"); 
break; 
default: printf("\n Wrong Selection !(选择错误,重选)\n"); 
getchar(); 
} 
} 
} 

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 0. 退 出\n\n"); 
} 

void read(void) 
{ 
long a; 
printf("input the number:"); 
scanf("%ld",&a); 
while(a>0){ 3 
inser(a); 
printf("input the number:"); 
scanf("%ld",&a); 
} 
} 
void inser(long b) 
{ 

Node *last,*current,*p; 
current=head; 
while(current!=NULL&&b>current->student.num){ 
last=current; 
current=current->next; 
} 

if(current==NULL||b<current->student.num){ 
printf("input the name,score:"); 
p=(Node *)malloc(sizeof(Node)); 
p->student.num=b; 
scanf("%s%f",p->student.name,&p->student.score); 
p->next=NULL; 
if(current==head){ 
p->next=head; 
head=p; 
} 
else{ 
p->next=current; 
last->next=p; 
} 
} 
else if(b==current->student.num) 
printf("error input a different number:"); 

} 

void print() 
{ 
Node *p=head; 
printf("学号 姓名 成绩:\n"); 
while(p!=NULL){ 
printf("%ld %s %f\n",p->student.num,p->student.name,p->student.score); 
p=p->next; 
} 4 
printf("\n"); 
} 
void find(long b) 
{ 
Node *p=head; 
while(p!=NULL&&b!=p->student.num) 
p=p->next; 
if(!p) printf("No found\n"); 
else { 
printf("学号 姓名 成绩\n"); 
printf("%ld %s %f\n",p->student.num,p->student.name,p->student.score); 
} 

} 

void searchname(char *s) 
{ 
Node *p=head; 
int flag=0; 
printf("学号 姓名 成绩:\n"); 
while(p!=NULL) 
{ 
if(strcmp(p->student.name,s)==0) 
{ 
printf("%ld %s %f\n",p->student.num,p->student.name,p->student.score); 
flag=1; 
p=p->next; 
continue; 
} 
else p=p->next; 
} 
if(!flag) printf("No find"); 
} 
Node * del(long n) 
{ 
Node *p=head,*last; 
while(p->student.num!=n){ 
last=p; 
p=p->next; 
} 
if(p==NULL) return p; 
else if(p==head) head=p->next; 
else last->next=p->next; 5 
return head; 
} 
void sort(int flag) 
{ 
/*flag==1 按分数排序 else 按学号排序*/ 
Node *p1,*p2,*k; 
float t1; 
long t2; 
char s[20]; 
for(p1=head;p1->next;p1=p1->next) 
{ 
k=p1; 
for(p2=p1->next;p2;p2=p2->next) 
if(flag==1&&k->student.score<p2->student.score||!flag&&k->student.num>p2->student.num) 
k=p2; 
if(k!=p1){ 
t1=p1->student.score; 
p1->student.score=k->student.score; 
k->student.score=t1; 
t2=p1->student.num; 
p1->student.num=k->student.num; 
k->student.num=t2; 
strcpy(s,p1->student.name); 
strcpy(p1->student.name,k->student.name); 
strcpy(k->student.name,s); 
} 
} 
} 

 

 

  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
一、学籍管理系统 1.问题提出 为了分析教学效果并进行相应的学籍处理,各学校每到期末都对综合成绩进行分类统计、上报成绩汇总结果等,这给每位老师和学籍管理人员带来很大工作量。使用学籍管理系统可以减少工作者的工作负担。 2.功能要求 循环显示如图7(a)所示的主菜单。 ………………………………………………….        .………………………………………………………        …………………………………………………………. 请输入选项编号(0 ~4):.        . 请输入选项编号(0 ~4):.        .请输入选项编号(0 ~4):. ………………………………………………….        .………………………………………………………        …………………………………………………………. . 1——录入成绩.                . 1——按学号排序.               . 1——生成并打印补考通知单 . . 2——统计成绩.                . 2——计算平均分并排序 .         . 2——生成并打印退学通知单 . . 3——处理学籍.                . 3——统计分数段.               . 3——生成并打印新名册. . 4——创新功能.                . 4——返回.                    . 4——返回. . 0——退出系统.                . 0——退出系统.                 . 0——退出系统. ……………………………………………………         ……………………………………………………….        …………………………………………………………. 图7(a) 学籍管理主菜单            (b)成绩统计子菜单               (c)学籍处理子菜单 在主菜单中选择1:录入成绩。假设某班的原始成绩形式如下: 学号        姓名        高数    英语    物理    编程    马哲 0909339105 Huangying  89      92      85     88     82 0909339102 Zhangchen  72      68      83     90     78 0909339108 Linan      91      84      90     79     81 …… 其中,原始数据的排列是无序的。系统应能够保留原始成绩单。 在主菜单中选择2:进入如图7(b)所示的子菜单,并统计成绩。在此可以计算平均分、统计各分数段、按学号排序、按平均分排序。在子菜单选择1时,将该班学生的成绩按学号升序排序后的顺序存入std.dat文件中,以方便打印。在子菜单选择2时,求出每位学生的平均分,并按平均分从高到低的顺序进行排序后,写入文件sort.dat中。在子菜单选择3时,统计出各门课、各分数段学生的人数,并如表1所示的形式输出。在子菜单选择4时,返回主菜单;选择0,退出整个系统。 在主菜单选择3:进入如图7(c)所示的子菜单,并处理学籍。为不及格的学生打印重考通知单时,应在通知单上写明重考的课程、时间和地点(由键盘输入)。为了参加多门课重考的学生完成补考,应避免时间重复。为3门以上不及格的学生打印退学通知单。通知单上应写明学生的学号、姓名、退学原因(几门课不及格,成绩多少)。删除已退学的学生信息,将该班中升入高年级的学生信息写入文件next.dat中。在子菜单选择4,返回主菜单;选择0,退出整个系统。 在主菜单中选择4:此项功能学生自由发挥,根据本组爱好增加与本题止相关的新功能。 在主菜单中选择0:显示结束信息(如“感谢使用本软件!已正常退出,按任意键结束。”),按任意键后,退出本功能。 表1 各门课、各分数段学生的人数 ……………………………………………………………………………………………………………….   . 90以上. 80~89分.70~79分.60~69分.60分以下. 高数.      .       .       .       .       . 英语.      .       .       .       .       . 物理.      .       .       .       .       . 编程.      .       .       .       .       . 马哲.      .       .       .       .       . ……………………………………………………………………………………………………………….
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

X-MTing

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值