C++ 学生成绩管理系统

// 学生成绩管理.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
// QQ 523857886
#include<iostream>
#include<string>
#define MAX 200
using namespace std;
struct student
{
    string xingming,  zhuanye, banji;

    float xuehao=0;
    float shuxue=0;
    float yingyu=0;
    float yuwen=0;
    float avg = 0;//平均值
};  

struct data
{
    int count=0; // 当前学生数组中学生的个数
    struct student stu[MAX]; // 学生数组
}dd;

// 显示主菜单
void menu()
{
    
    //略  此部分内容需要的M    Q523857886
}


// 查看所有学生信息
void view_data()
{
    int i;
    cout << "姓名\t学号\t专业\t班级\t数学\t英语\t语文\t平均分";
    cout<<"\n-------------------------------------------------------------------\n";
    for (i = 0; i < dd.count; i++)
        cout << dd.stu[i].xingming << "\t" << dd.stu[i].xuehao << "\t" << dd.stu[i].zhuanye << "\t" << dd.stu[i].banji << "\t" << dd.stu[i].shuxue << "\t"
        << dd.stu[i].yingyu << "\t" << dd.stu[i].yuwen << "\t" << dd.stu[i].avg << "\n";
    cout<<"\n-------------------------------------------------------------------\n";    
}

// 输入学生记录
void add_data()
{
    int b;
    int k = dd.count;
    while (k < MAX)
    {
        float tmp;

        cout << "请输入学生姓名:"; cin >> dd.stu[k].xingming;
        cout << "请输入学生学号:";

        cin >> tmp; 
        while (!cin)
        {
            char ch;
            while ((ch = getchar()) != '\n')
                continue;
            cout << "输入的不是数字,重新输入: ";
            cin.clear();
            cin >> tmp;
        }
        dd.stu[k].xuehao = tmp;

        cout << "请输入学生专业:"; cin >> dd.stu[k].zhuanye;
        cout << "请输入学生班级:"; cin >> dd.stu[k].banji; 
        

        cout << "请输入学生数学:"; cin >> tmp;
        while (!cin)
        {
            char ch;
            while ((ch = getchar()) != '\n')
                continue;
            cout << "输入的不是数字,重新输入: ";
            cin.clear();
            cin >> tmp;
        }      
        dd.stu[k].shuxue =tmp;

        cout << "请输入学生英语:"; cin >> tmp;
        while (!cin)
        {
            char ch;
            while ((ch = getchar()) != '\n')
                continue;
            cout << "输入的不是数字,重新输入: ";
            cin.clear();
            cin >> tmp;
        }
        dd.stu[k].yingyu = tmp;

        cout << "请输入学生语文:"; cin >> tmp; 
        while (!cin)
        {
            char ch;
            while ((ch = getchar()) != '\n')
                continue;
            cout << "输入的不是数字,重新输入: ";
            cin.clear();
            cin >> tmp;
        }

        dd.stu[k].yuwen = tmp;


     
        

        dd.count++; //需要提前置0,在主函数中。
        k = dd.count;
        cout<<"\n\n继续添加学生信息[按1回车继续 0回车返回,其他回车退出]:";
        
        
        cin >> b;
        if (b != 1)
        {
            cin.clear();
            break;
        }
        
    }
    
}


// 修改学生记录
void edit_data()
{
    int i, k=-1;
    float  xuehao;
    cout<<"\n请输入要修改学生的学号:";
    cin >> xuehao;

    while (!cin)
    {
        char ch;
        while ((ch = getchar()) != '\n')
            continue;
        cout << "输入的不是数字,重新输入: ";
        cin.clear();
        cin >> xuehao;
    }
    
    for (i = 0; i < dd.count; i++)
    {
        if (dd.stu[i].xuehao== xuehao)
        {
            k = i;
            break;
        }
    }
    if (k == -1)
    {
        cout << "\n\n没有找到该学生(学号-"<< xuehao<<")!";
    }
    else
    {
        cout << "请输入" << xuehao << "学生姓名:"; cin >> dd.stu[k].xingming;
        cout << "请输入"<< xuehao <<"学生专业:"; cin >> dd.stu[k].zhuanye;
        cout << "请输入" << xuehao << "学生班级:"; cin >> dd.stu[k].banji;
        float tmp;

        cout << "请输入" << xuehao << "学生数学:"; cin >> tmp;
        while (!cin)
        {
            char ch;
            while ((ch = getchar()) != '\n')
                continue;
            cout << "输入的不是数字,重新输入: ";
            cin.clear();
            cin >> tmp;
        }
        dd.stu[k].shuxue = tmp;

        cout << "请输入" << xuehao << "学生英语:"; cin >> tmp;
        while (!cin)
        {
            char ch;
            while ((ch = getchar()) != '\n')
                continue;
            cout << "输入的不是数字,重新输入: ";
            cin.clear();
            cin >> tmp;
        }
        dd.stu[k].yingyu = tmp;

        cout << "请输入" << xuehao << "学生语文:"; cin >> tmp;
        while (!cin)
        {
            char ch;
            while ((ch = getchar()) != '\n')
                continue;
            cout << "输入的不是数字,重新输入: ";
            cin.clear();
            cin >> tmp;
        }

        dd.stu[k].yuwen = tmp;
        
        cout<<"\n\n修改学生记录(学号-"<< xuehao <<")成功!";
    }
}

//删除记录
void delete_data()
{
    int i, k=-1;
    float  xuehao;
    cout << "\n请输入要修改学生的学号:";
    cin >> xuehao;

    while (!cin)
    {
        char ch;
        while ((ch = getchar()) != '\n')
            continue;
        cout << "输入的不是数字,重新输入: ";
        cin.clear();
        cin >> xuehao;
    }
    
    for (i = 0; i < dd.count; i++)
    {
        if (dd.stu[i].xuehao == xuehao)
        {
            k = i;//找到记录所在位置
            break;
        }
    }
    if (k == -1)
    {
        cout << "\n\n没有找到该学生(学号-" << xuehao << ")!";
    }
    else
    {
        for (i = k; i < dd.count - 1; i++)//将k位置的数据被k+1位置的信息覆盖
        {
            dd.stu[i] = dd.stu[i + 1];
        }
        dd.count--;

        cout << "\n\n删除学生记录(学号-" << xuehao << ")成功!";
    }
}

//学号查询成绩 //需要学号是有序的,不然实现不了折半查询
void qurey_data_xuehao()
{
    
    float  xuehao;
    cout << "\n请输入要修改学生的学号:";
    cin >> xuehao;
    while (!cin)
    {
        char ch;
        while ((ch = getchar()) != '\n')
            continue;
        cout << "输入的不是数字,重新输入: ";
        cin.clear();
        cin >> xuehao;
    }


    int low = 1;
    int high = dd.count;
    int mid;


    while (low <= high)
    {
        mid = (low + high) / 2;
        if (dd.stu[mid].xuehao == xuehao)
        {
            cout << "姓名\t学号\t专业\t班级\t数学\t英语\t语文";
            cout << "\n-------------------------------------------------------------------\n";

            cout << dd.stu[mid].xingming << "\t" << dd.stu[mid].xuehao << "\t" << dd.stu[mid].zhuanye << "\t" << dd.stu[mid].banji << "\t" << dd.stu[mid].shuxue << "\t"
                << dd.stu[mid].yingyu << "\t" << dd.stu[mid].yuwen << "\n";
            cout << "\n-------------------------------------------------------------------\n";

            return ;
        }
        else if (dd.stu[mid].xuehao > xuehao)
        {
            high = mid - 1;
        }        
        else
        {
            low = mid + 1;
        }
    }    
        cout << "\n\n没有找到该学生(学号-" << xuehao << ")!";     
}

void qurey_data_average() 
{
    int i;
   
    for (i = 0; i < dd.count; i++)   
        dd.stu[i].avg = (dd.stu[i].shuxue + dd.stu[i].yingyu + dd.stu[i].yuwen) / 3;   
    cout << "\n计算完毕~!\n";   
    
}

void sort_data()//排序 根据平均值排序
{
    int i, j, N;
    N = dd.count;
    for (i = 0; i < N - 1; i++) 
    {
        for (j = 0; j < N - 1 - i; j++)
        {
            if (dd.stu[j].avg < dd.stu[j + 1].avg) 
            { 
                student tmp; //临时变量
                tmp = dd.stu[j]; //交换
                dd.stu[j] = dd.stu[j + 1];
                dd.stu[j + 1] = tmp;
            }
        }

    }
    qurey_data_average();
    view_data();
}

int main() {
    int a;
    dd.count = 0;//开始0条记录
    
    menu();
    cin >> a;
    while (a) {
       //QQ 523857886
        menu();
        cin >> a;
    }
    return 0;
}

相当不错的一个成绩管理系统 #include #include #include #include using namespace std; enum {SUBJECT=5};//一共五门 typedef struct { char subject[10];//科目名称 int score;//科目成绩 }markinfo; typedef struct studentnode { markinfo mark[SUBJECT]; int totalmark; char name[10];//学生姓名 studentnode * next; }studentnode; class student { studentnode * head; public: student(); int addstudent(); ~student(); int countmark(); int sortbymark(); int save(); int show(); int display(); int readfiletolist(); int searchbyname(); }; student::student() //用构造函数来初始化。 { head=new studentnode; head->next=NULL; } //1.输入学生姓名、成绩等数据,并保存在链表中。 int student::addstudent() { studentnode * p; int i; char check; system("cls"); cout<<"**********************"<<endl; cout<<"请输入学生信息:"<<endl; do { p=new studentnode; cin.ignore(); cout<name); i=0; p->totalmark=0; do { cout<mark[i].subject); cout<>p->mark[i].score; } while(p->mark[i].score>100||p->mark[i].scoretotalmark=p->totalmark+p->mark[i].score; getchar(); } while(++i!=SUBJECT); if(head->next==NULL) { head->next=p;p->next=NULL; } else { p->next=head->next; head->next=p; } cout<next; if(p==NULL) { cout<<"没有学生,请重新输入"<<endl;system("pause");return 0; } else { cout<<"***************"<<endl; cout<<"学生成绩汇总:"<<endl; while(p) { cout<<"姓名:"<name<<" 总成绩:"<totalmark<next; } } system("pause"); return 0; } //4.输出所有学生成绩到一个文件中。 int student::save() { char address[35]; int i; studentnode * p=head->next; cout<<"请输入保存的地址"<<endl; cin.ignore(); gets(address); ofstream fout; fout.open(address,ios::app|ios::out); while(p) { fout<<"*"; fout<name<<"*"; i=0; while(i!=SUBJECT) { fout<mark[i].subject<<"*"; fout<mark[i].score; i++; } //fout<next; } fout.flush(); fout.close(); cout<next; while(p) { s=p->next; delete p; p=s; } delete head; } //3.按照总成绩大小对记录进行排序 int student::sortbymark() { studentnode *move1=head->next; studentnode *move2,*max,*pre1,*pre2,*maxpre,*s=move1; if(head->next==NULL) { cout<<"没有记录,请添加"<next!=NULL;pre1=move1,maxpre=pre1,move1=move1->next,max=move1) { for(pre2=move1,move2=move1->next;move2!=NULL;pre2=move2,move2=move2->next) if(move2->totalmark>max->totalmark) { maxpre=pre2; max=move2; } if(move1->next==max) //交换max和move1。 { pre1->next=max; move1->next=max->next; max->next=move1; move1=max; } else { s=move1->next; move1->next=max->next; max->next=s; maxpre->next=move1; pre1->next=max; move1=max; } } cout<<"已经按照从大到小排序"<next; int i; if(head->next==NULL){cout<<"没有学生记录,请添加"<<endl;system("pause"); return 0;} else { while(p) { cout<<"姓名:"<name; i=1; while(i!=SUBJECT+1) { cout<<"科目:"<mark[i-1].subject; cout<<" 成绩:"<mark[i-1].score; i++; } cout<next; } } system("pause"); return 0; } //6:从文件按读取记录 int student::display() { ifstream fin; char buf[100]; char str[25]; cout<<"请输入路径及文件名:"<<endl; cin.ignore(); gets(str); fin.open(str); if(!fin) { cout<<"没有此文件"<<endl; system("pause"); return 0; } while(fin) { fin.getline(buf,sizeof(buf)); cout<<buf<<endl; } system("pause"); return 0; } //8从文件中读取数据,并将数据保存在链表中 int student::readfiletolist() { ifstream fin; int i; char str[25]; cout<<"请输入路径及文件名:"<<endl; cin.ignore(); gets(str); fin.open(str); if(!fin) { cout<<"没有此文件"<totalmark=0; fin.getline(p->name,100,'*'); i=0; while(i!=SUBJECT) { fin.getline(p->mark[i].subject,100,'*'); fin>>p->mark[i].score; p->totalmark+=p->mark[i].score; i++; } if(head->next==NULL) { head->next=p; p->next=NULL; } else { p=head->next; head->next=p; } } cout<<"信息已经保存在链表中"<next==NULL) { cout<<"没有学生,请添加或者从文件中读取"<next; char findname[10]; int i; cout<name,findname)) { cout<<"经查找,找到该生信息如下:"<<endl<<endl; cout<<"姓名:"<name; i=1; while(i!=SUBJECT+1) { cout<<"科目:"<mark[i-1].subject; cout<<" 成绩:"<mark[i-1].score; i++; } cout<next; } cout<<"没有此学生,请添加或者从文件中读取"<<endl; system("pause"); return 0; } int showmenu() { int choice; char * menu[9]={ "1:输入学生成绩保存到链表\n", "2:计算每位学生总成绩\n", "3:按照总成绩大小对记录进行排序\n", "4:输出所有学生成绩到一个文件中\n", "5:显示新输入的学生信息\n", "6:从文件中读取信息\n", "7:将文件信息保存在链表中\n", "8:根据姓名查找学生记录\n", "9:结束程序\n" }; cout<<" "<<"*****************************************************"<<endl; cout<<" *"<<" "<<"学生成绩管理系统"<<" *"<<endl; cout<<" "<<"*****************************************************"<<endl; for(choice=0;choice<9;choice++) cout<<" "<<menu[choice]; cout<<" "<<"*****************************************************"<<endl; cout<<"please choose to continue"<>choice; } while(choice>9||choice<1); return choice; } int main() { int menuitem,flag=1; student stu; while(flag) { system("cls"); menuitem=showmenu(); switch(menuitem) { case 1:{stu.addstudent();break;} case 2:{stu.countmark();break;} case 3:{stu.sortbymark();break;} case 4:{stu.save();break;} case 5:{stu.show();break;} case 6:{stu.display();break;} case 7:{stu.readfiletolist();break;} case 8:{stu.searchbyname();break;} case 9:{flag=0;break;} } } return 0; }
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值