C++学生成绩管理(链表)

现在闲下来了,打算整理下之前写过代码,用来纪念我的大学生活。

这是遇到的第一个C++大作业。

问题描述如下:

设计一个“学生成绩管理系统”。主要实现学生信息的录入、添加、修改、删除、排序和查看等基本功能。

具体要求:

编写一个学生成绩管理程序。学生成绩以一个学生一条记录的形式存储,每个学生记录包含的信息有序号、学号、姓名及5门功课的成绩。

具体功能如下:

1、获取学生成绩。可以从文件中读取成绩,也可直接录入;

2、查询学生成绩,输入学生学号或姓名等信息后,显示学生在成绩单中的位置及所有信息;

3、添加学生成绩,在学生成绩单的指定位置添加学生成绩信息;

4、修改学生成绩,在学生成绩单中,修改指定学生的成绩信息;

5、删除学生成绩,在学生成绩单中,删除指定学生的成绩信息;

6、保存文件。当学生成绩单发生添加、修改、删除等变化后,都要对最终结果进行保存

代码如下:

头文件及链表

#include 
#include 
#include 
#include 
#include 
using namespace std;
class student
{public:int num1;long long num2;string name;double score1;double score2;double score3;double score4;double score5;
};class list//建立链表
{public:student stu;list *next;
} ;

操作类:

class operation
{public:list *l,*head,*bl,*ll;FILE *fp;operation(list *h);void menu(); //主菜单void add();//在第i个位置增加void modify();//修改void remove();//删除void find();//查询void open();//只读方式打开文件void save();//保存文件void paixu(); //重排序号
};

相应函数:

operation::operation(list *h)
{head=h;}void operation::add()//添加
{int i;cout << "              请输入要添加的位置                 " << endl;cin>>i;int x=1;l=new list;cout<<"请输入该学生的 "<>l->stu.num2 ;cout<<"姓名 ";cin>>l->stu.name ;cout<<"工科数学分析 的成绩 ";cin>>l->stu.score1 ;cout<<"线性代数A 的成绩 ";cin>>l->stu.score2;cout<<"大学物理AI 的成绩 ";cin>>l->stu.score3 ;cout<<"数据结构与算法设计(C++描述)的成绩 ";cin>>l->stu.score4;cout<<"中国近现代史纲要 的成绩 ";cin>>l->stu.score5;if(i==1)//加在第一个{l->next=head->next;head->next=l;}else//其他{for(bl=head->next; x+1!=i; bl=bl->next,x++); //要加的前一个人l->next=bl->next;bl->next=l;}cout<<"添加成功!"<>i;if(i==1){cout << "              请输入学号                 " << endl;cin>>num;for(l=head; l!=NULL&&l->stu.num2!=num; l=l->next);if(l!=NULL){cout << "序号:" << l->stu.num1 << endl<< "学号;" << l->stu.num2 << endl<< "姓名:" << l->stu.name << endl;cout << "工科数学分析 的成绩:" << l->stu.score1 << endl<< "线性代数A 的成绩:" << l->stu.score2 << endl;cout << "大学物理AI 的成绩:" << l->stu.score3 << endl<< "数据结构与算法设计(C++描述)的成绩:" << l->stu.score4 << endl<< "中国近现代史纲要 的成绩:" << l->stu.score5 << endl;}else{cout<<"未找到该学生"<>nam;student p;for(l=head; l!=NULL&&l->stu.name!=nam; l=l->next ); //找到这个名字if(l!=NULL)//找到了{cout << "序号:" << l->stu.num1 << endl<< "学号;" << l->stu.num2 << endl<< "姓名:" << l->stu.name << endl;cout << "工科数学分析 的成绩:" << l->stu.score1 << endl<< "线性代数A 的成绩:" << l->stu.score2 << endl;cout << "大学物理AI 的成绩:" << l->stu.score3 << endl<< "数据结构与算法设计(C++描述)的成绩:" << l->stu.score4 << endl<< "中国近现代史纲要 的成绩:" << l->stu.score5 << endl;}else //没找到{cout<<"未找到该学生"<>i;if(i==1){cout << "              请输入学号                 " << endl;cin>>num;for(l=head; (l!=NULL)&&(l->stu.num2  !=num); l=l->next ); //找到这个学号if(l!=NULL)//找到了{cout<<"已找到,请修改!"<>l->stu.num2 ;cout<<"姓名:";cin>>l->stu.name ;cout<<"工科数学分析 的成绩:" ;cin>>l->stu.score1 ;cout<<"线性代数A 的成绩:";cin>>l->stu.score2 ;cout<<"大学物理AI 的成绩:";cin>>l->stu.score3 ;cout<<"数据结构与算法设计(C++描述)的成绩:";cin>>l->stu.score4 ;cout<<"中国近现代史纲要 的成绩:";cin>>l->stu.score5 ;cout <<"      修改成功" << endl;//l->stu =p;}else //没找到{cout<<"未找到该学生"<>nam;student p;for(l=head; l!=NULL&&l->stu.name!=nam; l=l->next ); //找到这个名字if(l!=NULL)//找到了{cout<<"已找到,请修改!"<>p.num2 ;cout<<"姓名:";cin>>p.name ;cout<<"工科数学分析 的成绩:" ;cin>>p.score1 ;cout<<"线性代数A 的成绩:";cin>>p.score2 ;cout<<"大学物理AI 的成绩:";cin>>p.score3 ;cout<<"数据结构与算法设计(C++描述)的成绩:";cin>>p.score4 ;cout<<"中国近现代史纲要 的成绩:";cin>>p.score5 ;l->stu =p;cout <<"      修改成功" << endl;}else //没找到{cout<<"未找到该学生"<>i;if(i==1){cout << "              请输入学号                 " << endl;cin>>num;bl=head;if(bl->next->stu.num2 == num)//在第一个{bl=head->next;head->next=bl->next;delete bl;cout <<"      删除成功" << endl;}else{for(; bl->next !=NULL&&bl->next->stu.num2!=num; bl=bl->next); //要删的前一个人if(bl->next !=NULL)//有这个人(bl不是最后一个人){l=bl->next;//要删的这个人bl->next=l->next;delete l;cout <<"      删除成功" << endl;}else //没有这个人(bl是最后一个人){cout<<"未找到该学生"<>nam;bl=head;if(bl->next->stu.name==nam)//在第一个{bl=head->next;head->next=bl->next;delete bl;cout <<"      删除成功" << endl;}else{for(; bl->next !=NULL&&bl->next->stu.name!=nam; bl=bl->next); //要删的前一个人if(bl->next !=NULL)//有这个人(bl不是最后一个人){l=bl->next;//要删的这个人bl->next=l->next;delete l;cout <<"      删除成功" << endl;}else //没有这个人(bl是最后一个人){cout<<"未找到该学生"<> number && ifs >> schoolnumber && ifs >> name1 && ifs >> subject1 && ifs >> subject2 && ifs >> subject3 && ifs >> subject4 && ifs >> subject5 ;while(ifs >> l -> stu.num1 && ifs >> l -> stu.num2 && ifs >> l -> stu.name && ifs >> l -> stu.score1 && ifs >> l -> stu.score2 && ifs >> l -> stu.score3 && ifs >> l -> stu.score4 && ifs >> l -> stu.score5){ll->next=l;ll=ll->next;l->next=NULL;l=new list;}ifs.close();}void operation::paixu()//重排序号  
{int i=1;for(l=head->next; l!=NULL; l=l->next,i++){l->stu.num1=i;}
}void operation::save()//保存文件  
{ofstream ofs;paixu();ofs.open("test.txt" , std::ofstream::out | std::ofstream::trunc );l = head -> next ;ofs << "序号" << "\t" << "学号" << "\t" << "\t" << "姓名" << "\t" << "工科数学分析" << "\t" << "线性代数A" << "\t" << "\t" << "大学物理AI" << "\t" << "数据结构与算法设计(C++描述)" << "\t" << "中国近现代史纲要" << "\n";while( l != NULL){ofs << l->stu.num1 << "\t" << l->stu.num2 << "\t" << l->stu.name << "\t" << l->stu.score1 << "\t" << "\t" << l->stu.score2 << "\t" << "\t" << l->stu.score3 << "\t" << "\t" << l->stu.score4 << "\t" << "\t" << "\t" << "\t" << l->stu.score5 << "\n";l = l -> next;}ofs.close();cout<<"保存成功!" <

主函数:

int main()
{int x,i;long long num;string nam;student stu;list *head,*l,*ll;head=new list;head->next=NULL;l=head;operation op(head);operation *p=&op;p->menu();p->open();cin>>x;while(x!=0){switch (x){case 1:p -> find();break;case 2:p -> add();break;case 3:p -> modify();break;case 4:p -> remove();break;case 5:p -> save();break;}system("cls");p->menu();cin>>x;};return 0;
}

文件里的内容长这样:

仍然有些bug......


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部