学生成绩管理系统

简介:
#include <iostream>
#include <cstring>
#include <algorithm>
#include <cstdio>
using namespace std;
struct sa
{
    int num;
    char name[105];
    char sex[3];
    double score[5];
    double ave;
    double sum;
    int rank;
}data[105];
int cmp_upid(const sa&a, const sa&b)//按学号升序
{
    return a.num<b.num;
}
int cmp_downid(const sa&a, const sa&b)//按学号降序
{
    return a.num>b.num;
}
int cmp_upname(const sa&a, const sa&b)//按名字升序
{
    return strcmp(a.name,b.name)<0;
}
int cmp_downname(const sa&a, const sa&b)//按名字降序
{
    return strcmp(a.name,b.name)>0;
}
int cmp_uprank(const sa&a, const sa&b)//按排名升序
{
    return a.sum<b.sum;
}
int cmp_downrank(const sa&a, const sa&b)//按排名降序
{
    return a.sum> b.sum;
}
int _k=0,tmp=0;//_k是总的学生数目
void add()//追加
{
    printf("学号:");
    scanf("%d",&data[_k].num);
    printf("姓名:");
    cin>>data[_k].name;
    printf("性别:");
    scanf("%s",data[_k].sex);
    data[_k].sum=0.0;
    for(int i=0;i<5;i++)//5门课程的成绩
    {
        cin>>data[_k].score[i];
        data[_k].sum+=data[_k].score[i];
    }
    data[_k].ave=data[_k].sum/5.0;
    _k++;
    return;
}
void show()//显示在屏幕上
{
    for(int i=0; i<_k; i++)
        printf("%d %s %s %.2lf %.2lf %.2lf %.2lf %.2lf %.2lf %.2lf %d\n",data[i].num,data[i].name,data[i].sex,data[i].score[0],
               data[i].score[1],data[i].score[2],data[i].score[3],data[i].score[4],data[i].ave,data[i].sum,data[i].rank);
}
struct sa *Find()//查询
{
    int a;
    printf("请输入学生的学号\n");
    cin>>a;
    int flag=0;
    struct sa *p;
    for(int i=0;i<_k;i++)
    if(data[i].num==a)
    {
        printf("%d %s %s %.2lf %.2lf %.2lf %.2lf %.2lf %.2lf %.2lf %d\n",data[i].num,data[i].name,data[i].sex,data[i].score[0],
               data[i].score[1],data[i].score[2],data[i].score[3],data[i].score[4],data[i].ave,data[i].sum,data[i].rank);
        flag=1;
        p=&data[i];
        return p;
    }
    if(flag==0)
    {
        puts("Sorry,您输入的学号错误,请重新输入");
        return NULL;
    }
}
struct sa * xg()//数据修改
{
    int num0,j,m;
    double sc;
    printf("请输入学生的学号  输入学生的课程代号  输入学生修改后的成绩\n");
    cin>>num0>>j>>sc;
    struct sa *p;
    for(int i=0;i<_k;i++)
    {
       if(data[i].num==num0)
        {
            data[i].sum=0.0;
           for(int k=0;k<5;k++)
            {
                if(k==j)
                data[i].score[k]=sc;
                data[i].sum+=data[i].score[k];
            }
            data[i].ave=data[i].sum/3.0;
            p=&data[i];
        }
    }
    return p;
}
struct sa *del()//数据删除
{
    int num0;
    puts("请输入要删除的学号");
    cin>>num0;
    struct sa *p;
    for(int i=0;i<_k;i++)
    {
        if(data[i].num==num0)
        {
            p=&data[i];
        }
        else
        printf("%d %s %s %.2lf %.2lf %.2lf %.2lf %.2lf %.2lf %.2lf\n",data[i].num,data[i].name,data[i].sex,data[i].score[0],
               data[i].score[1],data[i].score[2],data[i].score[3],data[i].score[4],data[i].ave,data[i].sum);
    }
    return p;
}
void sort_pe()
{
    cout<<"0.按学生学号排序:"<<endl;
    cout<<"1.按学生姓名排序:"<<endl;
    cout<<"2.按学生排名排序:"<<endl;
    int m,n;
    cin>>m>>n;
    switch(m)
    {
        case 0:
        {
            cout<<"1.升序:"<<endl;
            cout<<"0.降序:"<<endl;
           if(n == 1)
               sort(data,data+_k,cmp_upid);
           else if(n == 0)
               sort(data,data+_k,cmp_downid);
           else
               cout<<"Sorry"<<endl;
        }
        case 1:
        {
            cout<<"1.升序:"<<endl;
            cout<<"0.降序:"<<endl;
            if(n%2 == 1)
               sort(data,data+_k,cmp_upname);
            else
               sort(data,data+_k,cmp_downname);
        }
        case 2:
        {
            cout<<"1.升序:"<<endl;
            cout<<"0.降序:"<<endl;
            if(n%2 == 1)
               sort(data,data+_k,cmp_uprank);
            else
               sort(data,data+_k,cmp_downrank);
        }
    }
    for(int i=0; i<_k; i++)
    {
         int ans=1;
            for(int j=0; j<_k; j++)
              if(data[i].sum<data[j].sum)
                ans++;
        data[i].rank=ans;
    }
}
void save(char *filename)//保存文件
{
    FILE *fp = fopen(filename,"at");
    for(int i=tmp; i<_k; i++)
    {
        fprintf(fp,"%d %s %s %.2lf %.2lf %.2lf %.2lf %.2lf %.2lf %.2lf %d\n",data[i].num,data[i].name,data[i].sex,data[i].score[0],
            data[i].score[1],data[i].score[2],data[i].score[3],data[i].score[4],data[i].ave,data[i].sum,data[i].rank);
    }
    fclose(fp);
    tmp = _k;
    return ;
}
void read(char *filename)
{
    char temp;
    FILE *fp;
    fp = fopen(filename,"r");
    while((temp = fgetc(fp))!=EOF)
    {
        printf("%c",temp);
    }
    fclose(fp);
    return ;
}
void build()
{
    cout<<"请输入新建文件名称: ";
}
int main()
{
  while(1)
  {
      cout<<"**********************************************************************"<<endl;
      cout<<"〓〓〓〓〓〓     学 生 成 绩 管 理 系  统       〓〓〓〓〓〓〓〓"<<endl;
      cout<<"〓〓〓〓〓                〓〓〓〓〓"<<endl;
      cout<<"〓〓〓〓〓〓〓       1.增加学生信息             〓〓〓〓〓〓〓"<<endl;
      cout<<"〓〓〓〓〓〓〓       2.修改学生信息             〓〓〓〓〓〓〓"<<endl;
      cout<<"〓〓〓〓〓〓〓       3.显示学生信息             〓〓〓〓〓〓〓"<<endl;
      cout<<"〓〓〓〓〓〓〓       4.查询学生信息             〓〓〓〓〓〓〓"<<endl;
      cout<<"〓〓〓〓〓〓〓         5.删除学生信息             〓〓〓〓〓〓〓"<<endl;
      cout<<"〓〓〓〓〓〓〓       6.对学生信息进行排序       〓〓〓〓〓〓〓"<<endl;
      cout<<"〓〓〓〓〓〓〓       7.保存学生信息至记录文件   〓〓〓〓〓〓〓"<<endl;
      cout<<"〓〓〓〓〓〓〓       8.从记录文件读取学生信息   〓〓〓〓〓〓〓"<<endl;
      cout<<"〓〓〓〓〓〓〓       9.新建学生信息文件         〓〓〓〓〓〓〓"<<endl;
      cout<<"〓〓〓〓〓〓〓         0.运行结束                 〓〓〓〓〓〓〓"<<endl;

      cout<<"\n\t\t\n\t\t请选择:"<<endl;

      int m;
      cin>>m;
      switch(m)
      {
        case 0:
             return 0;
        case 1:
            add();break;
        case 2:
            xg();break;
        case 3:
            show();break;
        case 4:
            Find();break;//查询
        case 5:
            del(); break;
        case 6:
            sort_pe();break;
        case 7:
            save("学生管理系统.txt");break;
        case 8:
            read("学生管理系统.txt");break;
        case 9:
            build();break;
        default :
            puts("Sorry,您输入的编号不在操作步骤里面,请重新选择,谢谢\n");break;
      }
      cout<<endl;
      cout<<"---------------lalalalala--------------"<<endl;
      cout<<endl;
  }
    return 0;
}
目录
相关文章
|
编解码
A/D转换器的转换精度的介绍
A/D转换器的转换精度 一、引言 A/D转换器(Analog-to-Digital Converter)是一种将模拟信号转换为数字信号的设备,广泛应用于各个领域,如通信、仪器仪表、自动控制等。转换精度是评价A/D转换器性能的重要指标之一,它决定了转换器对输入信号的准确度和分辨率。本文将介绍A/D转换器的转换精度及其影响因素,并探讨提高转换精度的方法和技术。 二、转换精度的定义 A/D转换器的转换精度通常用位数(bits)来表示,表示转换器输出数字信号的二进制位数。例如,一个12位A/D转换器可以将模拟信号转换为12位的二进制数字信号。转换精度越高,表示能够更准确地将模拟信号转换为数字信号,
841 0
浅谈select,poll和epoll的区别
云栖号资讯:【点击查看更多行业资讯】在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! select,poll和epoll其实都是操作系统中IO多路复用实现的方法。 select select方法本质其实就是维护了一个文件描述符(fd)数组,以此为基础,实现IO多路复用的功能。
浅谈select,poll和epoll的区别
|
4月前
|
缓存 算法 数据挖掘
深入理解缓存更新策略:从LRU到LFU
【10月更文挑战第7天】 在本文中,我们将探讨计算机系统中缓存机制的核心——缓存更新策略。缓存是提高数据检索速度的关键技术之一,无论是在硬件还是软件层面都扮演着重要角色。我们会详细介绍最常用的两种缓存算法:最近最少使用(LRU)和最少使用频率(LFU),并讨论它们的优缺点及适用场景。通过对比分析,旨在帮助读者更好地理解如何选择和实现适合自己需求的缓存策略,从而优化系统性能。
102 3
|
8月前
|
安全 网络虚拟化
vlan划分详解
vlan划分详解
|
8月前
|
知识图谱 C++
大学物理-实验篇——用拉伸法测定金属丝的杨氏(弹性)模量(胡克定律、杨氏模量、平面反射镜、三角函数、螺旋测微器)
大学物理-实验篇——用拉伸法测定金属丝的杨氏(弹性)模量(胡克定律、杨氏模量、平面反射镜、三角函数、螺旋测微器)
537 0
|
9月前
|
C语言
深入理解C语言中的printf函数及数据输出
深入理解C语言中的printf函数及数据输出
624 0
|
存储
操作系统第五章_03 假脱机技术 (SPOOLing技术)
操作系统第五章_03 假脱机技术 (SPOOLing技术)
811 0
操作系统第五章_03 假脱机技术 (SPOOLing技术)
|
人工智能 项目管理 数据库
超强笔记软件之Notion
超强笔记软件之Notion
369 0
|
安全 网络安全 数据安全/隐私保护
|
移动开发 安全 数据安全/隐私保护
多端可接入,实现随时随地登录无影云桌面
多端可接入,实现随时随地登录无影云桌面
2515 0

热门文章

最新文章