C语言学籍管理系统

#include <stdio.h>
#define N 6
struct Student//定义结构体学生信息变量。
{
    int num;
    int clas;
    char name[20];
    float score1;
    float score2;
    float score3;
    float aver;
} stu[N],*p=stu;
char no[20]= {'n','o'},yes[20]= {'y','e','s'};//定义全局变量yes,no进行strcmp的比较。
int main()//主函数。
{
    int opt,i;
    char xuanze[20];
    void printmenu(void);
    void print(struct Student stu);
    void input(struct Student stu[N]);
    void delet(struct Student stu[N]);
    void select(struct Student stu[N]);
    void order(struct Student stu[N]);
    void out(struct Student stu[N]);


    printmenu();//输出菜单。
    scanf("%d",&opt);//输入选项。
    while (opt!=6)//进行菜单选择。
    {
        if (opt==1)
        {
            input(p);
        }
        else if (opt==2)
        {
            delet(p);
        }
        else if (opt==3)
        {
            select(p);
        }
        else if (opt==4)
        {
            order(p);
        }
        else if (opt==5)
        {
            out(p);
        }


        else
        {
            printf("Wrong choice.\n");
        }


        printmenu();//再次输出菜单。
        scanf("%d",&opt);//输入选项。
    }






    return 0;
}
void printmenu(void)//菜单输出函数。
{
    printf("1.input\n");
    printf("2.delete\n");
    printf("3.select\n");
    printf("4.order\n");
    printf("5.output\n");
    printf("6.quit\n");
    printf("please input your option\n");
    return 0;
}


void print(struct Student stu)//输出学生信息函数。
{
    printf("%4d,",stu.num);
    printf("%d,",stu.clas);
    printf("%s,",stu.name);
    printf("%3.1f,",stu.score1);
    printf("%3.1f,",stu.score2);
    printf("%3.1f,",stu.score3);
    printf("%4.1f\n",stu.aver);


    return 0;
}


void input(struct Student stu[N])//输入学生信息函数。
{
    int i;
    char xuanze[20];
    for (i=0; i<N; i++)
    {
        printf("Id ");
        scanf("%d",&stu[i].num);
        printf("class ");
        scanf("%d",&stu[i].clas);
        printf("name ");
        scanf("%s",&stu[i].name);
        printf("score1 ");
        scanf("%f",&stu[i].score1);
        printf("score2 ");
        scanf("%f",&stu[i].score2);
        printf("score3 ");
        scanf("%f",&stu[i].score3);
        stu[i].aver=(stu[i].score1+stu[i].score2+stu[i].score3);
        printf("continue?\n");
        scanf("%s",&xuanze);
        if ((strcmp(xuanze,no))==0)
            break;
    }
    return 0;
}


void delet(struct Student stu[N])//删除学生信息函数。
{
    void order(struct Student stu[N]);
    int con(char str[]);
    char c[20],xuanze[20],*str=c;
    int s=0,i,j;
    scanf("%s",&c);
    if ((isdigit(c[1]))==1)
    {
        s=con(str);
        for (i=0; i<N; i++)
        {
            if (stu[i].num==s)
            {
                for (j=i; j<N; j++)
                {
                    stu[j]=stu[j+1];
                }
            }
        }


    }
    else
    {
        for (i=0; i<N; i++)
        {
            if ((strcmp(c,stu[i].name))==0)
            {
                for (j=i; j<N; j++)
                {
                    stu[j]=stu[j+1];
                }
            }
        }


    }
    order(p);


    printf("continue?\n");
    scanf("%s",&xuanze);


    if ((strcmp(xuanze,yes))==0)
        delet(p);








    return 0;






}


void select(struct Student stu[N])//选择学生信息函数。
{
    int banji,i;
    char xuanze[20];
    scanf("%d",&banji);
    for (i=0; i<N; i++)
    {
        if ((stu[i].clas==banji)||(stu[i].num==banji))
        {
            print(stu[i]);
        }
    }
    printf("continue?\n");
    scanf("%s",&xuanze);




    if ((strcmp(xuanze,yes))==0)
        select(p);


    return 0;


}


void order(struct Student stu[N])//学生信息排序函数。
{
    int i,j;
    struct Student temp;
    void print(struct Student stu);
    for (i=0; i<N; i++)
    {
        for (j=i; j<N; j++)
        {
            if (stu[i].clas>stu[j].clas)
            {
                temp=stu[i];
                stu[i]=stu[j];
                stu[j]=temp;
            }
            else if (stu[i].clas==stu[j].clas)
            {
                if (stu[i].aver<stu[j].aver)
                {
                    temp=stu[i];
                    stu[i]=stu[j];
                    stu[j]=temp;
                }
            }
        }


    }


    for (i=0; i<N; i++)
    {
        if (stu[i].num!=0)
        {
            print(stu[i]);
        }
    }










    return 0;
}


void out(struct Student stu[N])//学生信息输出函数。
{
    order(p) ;
    return 0;
}
int con(char str[])//字符转化为数字的函数。
{
    int rt=0,i;
    for (i=0; i<20&&str[i]!='\0'; i++)
    {
        rt=rt*10+(str[i]-'0');
    }


    return rt;
}

 

一、学籍管理系统 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分以下. 高数.      .       .       .       .       . 英语.      .       .       .       .       . 物理.      .       .       .       .       . 编程.      .       .       .       .       . 马哲.      .       .       .       .       . ……………………………………………………………………………………………………………….
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值