问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

C++建立学生管理系统,

发布网友 发布时间:2022-09-05 08:25

我来回答

1个回答

热心网友 时间:2024-12-02 03:44

#include<string>
#include <fstream>
#include<sstream>
#include<iomanip>
using namespace std;

//结点类,用于存放学生的各种数据
class Node{
public:
int id; //学号
string name; //姓名
string grade; //等级
double english; //英语
double math; //数学
double c; //C++
double sum; //总分
double average;
Node *next; //指向下一结点的指针
Node(int nid=0,string nname="noname", //构造函数,初始化变量
double e=0,double m=0,double cl=0,
double s=0 ,double a=0,string g="ng");
};

Node::Node(int nid,string nname,double e,double m,double cl,double s,double a,string g){
id=nid;
name=nname;
next=NULL;
english=e;
math=m;
c=cl;
sum=s;
average=a;
grade=g;

}
//class NOde结束

//Link类,把数据以链表的形式存储,链表的每个结点为一个Node对象
class Link{
private:
Node *head; //链表的头指针,为Node对象类型的指

public :
Link();//构造函数,初始化变量
bool linkIsEmpty();//判断链表是否为空
void linkInsert(Node *newnode);//向链表中插入新的结点
bool linkDelete(int nid);//从链表中删除的结点
void linkClear();//清空链表中数据
void linkView();//查看链表中数据
void linkGrade(Node *p1);//计算等级
void linkAverageTotle();//按平均分统计
Node* linkFind(int nid);//在链表中查找id为nid结点,返回指向该结点的指针
Node* getHead();//获取头指针
};

Link::Link(){ //构造函数,初始化链表为空
head=NULL;
}

bool Link::linkIsEmpty(){ //判断链表是否为空,空则返回true
return(head==NULL);
}

void Link::linkInsert(Node *newnode){//按id值从小到大的顺序,插入新的结点
Node *p1;
if(!head)//链表为空的情况
head=newnode;
else if((head->id)>(newnode->id)){//插入到第一个结点的情况
newnode->next=head;
head=newnode;
}
else{//插入到第二个及以后情况
p1=head;
while(1){
if(!(p1->next)){
p1->next=newnode;
break;
}
else if((p1->next)->id>newnode->id){
newnode->next=p1->next;
p1->next=newnode;
break;
}
p1=p1->next;
}
}
}

bool Link::linkDelete(int nid){//删除结点,成功则返回true
Node *p;
if(head==NULL)//链表为空的情况
return false;
if(head->id==nid){//删除的为第一个结点的情况
head=head->next;
return true;
}
p=head;
while(p->next){//删除的为第二个及以后结点的情况
if((p->next)->id==nid){
p->next=(p->next)->next;
return true;
}
p=p->next;
}
return false;
}

void Link::linkClear(){//清空链表
head=NULL;
}

void Link::linkView(){//显示链表数据
Node *p=head;

cout<<setw(10)<<"学号"<<setw(8)<<"姓名"<<setw(8)<<"英语"<<setw(8)
<<"数学"<<setw(8)<<"C++"<<setw(8)<<"总分"<<setw(8)<<"平均分"<<setw(8)<<"等级"<<endl;
while(p){
(p->sum)=(p->english)+(p->math)+(p->c);//计算总分
(p->average)=((p->english)+(p->math)+(p->c))/3;//计算平均成绩
linkGrade(p);//计算等级
cout<<setw(10)<<p->id<<setw(8)<<p->name<<setw(8)<<p->english
<<setw(8)<<p->math<<setw(8)<<p->c<<setw(8)<<p->sum<<setw(8)
<<p->average<<setw(8)<<p->grade<<endl;
p=p->next;
}

}

void Link::linkGrade(Node *p1){ // 计算等级
while(p1){
if(p1->average>=90&&p1->average<=100)
p1->grade="优";
else if(p1->average>=80&&p1->average<90)
p1->grade="良好";
else if(p1->average>=70&&p1->average<80)
p1->grade="中等";
else if(p1->average>=60&&p1->average<=70)
p1->grade="合格";
else
p1->grade="不合格";

p1=p1->next;
}
}
void Link::linkAverageTotle(){//按学生平均分统计
int a=0,b=0,c=0,d=0,e=0,f=0;
double averagesum=0,asum=0,aaverage=0,paverage=0;
Node *p3=head;
while(p3){
if(p3->average>=90&&p3->average<=100)
a+=1;
else if(p3->average>=80&&p3->average<90)
b+=1;
else if(p3->average>=70&&p3->average<80)
c+=1;
else if(p3->average>=60&&p3->average<70)
d+=1;
else
e+=1;
asum+=p3->sum;
aaverage+=p3->average;
p3=p3->next;
}
f=a+b+c+d+e;
averagesum=asum/f;
paverage=aaverage/f;
cout<<"|-------------------------------------------------------|"<<endl;
cout<<"| 总 人 数:"<<f<<endl;
cout<<"|-------------------------------------------------------|"<<endl;
cout<<"| 优 人 数:"<<a<<" | "<<"优 秀 率: "<<a*100/f<<"%"<<endl;
cout<<"|-------------------------------------------------------|"<<endl;
cout<<"| 良 好 的人数:"<<b<<" | "<<"良 好 率: "<<b*100/f<<"%"<<endl;
cout<<"|-------------------------------------------------------|"<<endl;
cout<<"| 中 等 的人数:"<<c<<" | "<<"中 等 率: "<<c*100/f<<"%"<<endl;
cout<<"|-------------------------------------------------------|"<<endl;
cout<<"| 所有合格人数:"<<a+b+c+d<<" | "<<"合 格 率: "<<(a+b+c+d)*100/f<<"%"<<endl;
cout<<"|-------------------------------------------------------|"<<endl;
cout<<"| 不 合 格 数:"<<e<<" | "<<"不合格率: "<<e*100/f<<"%"<<endl;
cout<<"|-------------------------------------------------------|"<<endl;
cout<<"| 总分的平均分:"<<averagesum<<" | "<<"所有科目的平均分:"<<paverage<<endl;
cout<<"|-------------------------------------------------------|"<<endl;
}

Node* Link::linkFind(int nid){//查找id值为nid的结点,返回该结点的指针
Node *p=head; //没找到符合条件的结点的话,返回的指针值为NULL
while(p){
if(p->id==nid)
break;
else
p=p->next;
}
return p;
}
Node* Link::getHead(){
return head;
}
//class Link 结束

//类Student,用于包装Link类及菜单操作
class Student{
private:
Link slink;//Link对象成员
bool k;//记录数据是否被修改
public:
Student();
void studentClear();
void studentInsert();
void studentDelete();
void studentFind();
void studentView();
void studentLoad();
void studentSave();
void studentAverageTotle();//按平均分数统计等级
void Exit();//退出程序
void showMenu();//显示菜单
void showTip();//显示操作提示
void doMenu(char n);//执行相应菜单项功能
};
Student::Student(){
Link();//调用成员对象的构造函数
studentLoad();//从文件中读取数据,创建链表
k=false;//设置数据被修改
}

void Student::studentClear(){//清空学生记录
slink.linkClear();
cout<<"成功清空学生记录!"<<endl;
}

void Student::studentInsert(){//插入学生记录
Node *p=new Node();

cout<<"请输入学号:";
cin>>p->id;
cout<<"请输入姓名:";
cin>>p->name;
if(!slink.linkFind(p->id)){//判断学号是否存在

slink.linkInsert(p);
k=true;
}
else
cout<<"学号为"<<p->id<<"的学生已存在,插入失败!"<<endl;
cout<<"请输入成绩:"<<endl;
cout<<"英语:";
cin>>p->english;
cout<<endl;
cout<<"数学:";
cin>>p->math;
cout<<endl;
cout<<"C++:";
cin>>p->c;
cout<<endl;
(p->sum)=(p->english)+(p->math)+(p->c);//计算总分
(p->average)=((p->english)+(p->math)+(p->c))/3;//计算平均成绩

}

void Student::studentDelete(){//删除学生记录
int i;
if(slink.linkIsEmpty())//链表为空的情况
cout<<"没有学生记录!"<<endl;
else{
cout<<"请输入学号:";
cin>>i;
if(slink.linkDelete(i)){
cout<<"成功删除学号为"<<i<<"的学生记录!"<<endl;
k=true;
}
else
cout<<"没有找到学号为"<<i<<"的学生!"<<endl;
}
}

void Student::studentFind(){//查找某学号的学生记录
int n;
Node *p;
if(slink.linkIsEmpty())//链表为空的情况
cout<<"没有学生记录!"<<endl;
else{
cout<<"请输入要查找的学号:";
cin>>n;
p=slink.linkFind(n);//获得找到的结点的指针
if(p){//指针值不为NULL时
(p->sum)=(p->english)+(p->math)+(p->c);//计算总分
(p->average)=((p->english)+(p->math)+(p->c))/3;//计算平均成绩
slink.linkGrade(p);
cout<<setw(6)<<"学号"<<setw(8)<<"姓名"<<setw(8)<<"英语"
<<setw(8)<<"数学"<<setw(8)<<"C++"<<setw(8)<<"总分"<<setw(8)
<<"平均分"<<setw(8)<<"等级"<<endl;
cout<<setw(6)<<p->id<<setw(8)<<p->name<<setw(8)<<p->english
<<setw(8)<<p->math<<setw(8)<<p->c<<setw(8)<<p->sum<<setw(8)<<p->average
<<setw(8)<<p->grade<<endl;
}
else//指针值为NULL时
cout<<"没有找到学号为"<<n<<"的学生记录!"<<endl;
}
}

void Student::studentView(){//显示所有学生的记录
if(slink.linkIsEmpty())
cout<<"没有学生记录!"<<endl;
else
slink.linkView();
}

void Student::studentLoad(){//从文件中读入数据,创建链表
Node *p;
int nid;
ifstream infile("data.txt");
if(!infile)
cerr<<"错误:数据文件不能打开!\n";
else
while(infile>>nid){//读取学号,直到读空
p=new Node();
p->id=nid;
infile>>p->name>>p->english>>p->math>>p->c>>p->sum>>p->average>>p->grade;//读取姓名
slink.linkInsert(p);
}
infile.close(); //关闭文件
}

void Student::studentSave(){//将数据保存到文件
Node *p=slink.getHead();
ofstream outfile("data.txt");
if(!outfile)
cerr<<"错误:数据文件不能打开!\n";
else{
while(p){
outfile<<p->id<<' '<<p->name<<' '<<p->english<<' '<<p->math<<' '
<<p->c<<' '<<p->sum<<' '<<p->average<<' '<<p->grade<<endl;
p=p->next;
}
k=false;
cout<<"保存成功!"<<endl;
}
}

void Student::studentAverageTotle(){
if(slink.linkIsEmpty())
cout<<"没有学生记录!"<<endl;
else
slink.linkAverageTotle();
}
void Student::Exit(){
char s='Y';
if(k){//判断数据是否修改
cout<<"数据已经改变,是否保存?(y/n):";
cin>>s;
if(s=='y'||s=='Y')
studentSave();
}
cout<<"已安全退出,";
system("pause");
exit(0);
}

void Student::showMenu(){
cout<<" "<<"|------------------------------------------------|"<<endl;
cout<<" "<<"| 学生信息管理系统 |"<<endl;
cout<<" "<<"|------------------------------------------------|"<<endl;
cout<<" "<<"| 1. 清空:清除所有学生数据 |"<<endl;
cout<<" "<<"|------------------------------------------------|"<<endl;
cout<<" "<<"| 2. 添加:插入一条学生数据 |"<<endl;
cout<<" "<<"|------------------------------------------------|"<<endl;
cout<<" "<<"| 3. 删除:删除指定学生数据 |"<<endl;
cout<<" "<<"|------------------------------------------------|"<<endl;
cout<<" "<<"| 4. 查找:查找指定学生数据 |"<<endl;
cout<<" "<<"|------------------------------------------------|"<<endl;
cout<<" "<<"| 5. 显示:显示所有学生数据 |"<<endl;
cout<<" "<<"|------------------------------------------------|"<<endl;
cout<<" "<<"| 6. 保存:保存所有学生数据 |"<<endl;
cout<<" "<<"|------------------------------------------------|"<<endl;
cout<<" "<<"| 7. 统计:按学生平均分统计 |"<<endl;
cout<<" "<<"|------------------------------------------------|"<<endl;
cout<<" "<<"| 0. 退出:安全的退出本系统 |"<<endl;
cout<<" "<<"|------------------------------------------------|"<<endl<<endl;
}

void Student::showTip(){
cout<<endl;
cout<<"-------------------操作完成---------------------"<<endl;
cout<<"-----------------选择0-7继续-------------------"<<endl;
cout<<"请选择:";
}

void Student::doMenu(char n){
switch(n){
case '1':
studentClear();break;
case '2':
studentInsert();break;
case '4':
studentFind();break;
case '3':
studentDelete();break;
case '5':
studentView();break;
case '6':
studentSave();break;
case '7':
studentAverageTotle();break;
case '0':
Exit();break;
default:cout<<"输入错误!";
}
}

int main(){
Student s;
char i='9';
s.showMenu();
cout<<"选择对应数字进行操作:";
while(1){
cin>>i;
system("cls"); //清除屏幕
s.showMenu();
s.doMenu(i);
s.showTip();
}
}
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
梦见和同性发生关糸了 梦见和同性朋友发生亲密关系 学生党如何科学护肤? 学生党该怎么基础护肤? 有什么美容护肤的技巧适合学生党? 怎么@全部成员啊? 新洲摩尔城一楼小吃租金多少 武汉王家湾有哪些广场 你好 请问 晚上6点开始 学瑜伽 可以吗? 因为我想在下班时间去 锻炼锻 ... 电脑联网有哪些条件台式电脑无线上网需要具备哪些条件 为什么有人用node.js写操作系统(nodeOs),而不用perl,ruby,python... 帮个忙 我急求 用C语言做一个学生信息管理系统 存储方式 数组 链表 文... 毕设要求写一个基于HTML5的cms系统,请问cms系统到底是什么, nodejs 能写管理系统么 干海葵怎么做好吃 关于爱情的美文欣赏范文5篇 人寿团体意外伤害保险范本 我梦见自己的心被人挖出来,我感到有点痛,单还活着,这预示着什么? ...果子大多数外国人都爱吃,中国还有哪些让老外“欲罢不能”的美食? 保费忘存钱了怎么办 win和linux、unix的记事本的数据结构是什么 ubuntu(类linux)系统,如何让记事本显示行号。是记事本,不是vi。 LeeGuitars在哪有卖? 联通的无线有流量使用限制吗? 公众有什么作用 求助MOD人物怎么替换 上海九院埋线双眼皮需要拆线吗 上海那里有电脑外设的批发市场? 我是在郑州做电脑外设批发的,价格便宜,质量稳定,怎样才能快速推广我的产... oppo来电手机黑屏怎么解决 路西法,等级炮 中西部高校基础能力建设工程的主要任务 请问广东中烟公司出品的软盒经典双喜香烟多少钱一包? 双喜经典(软装)1906何年推出市场 双喜软经典属哪类烟 经典红双喜多少钱一盒 硬经典红双喜多少钱? 红双喜世纪经典多少钱一盒? 中西部高校基础能力建设工程的工程背景 中西部高校基础能力建设工程 -高校 重庆这3所大学,比一般的985、211大学要厉害 我家有只鸡老是抱窝,有时居然还会下蛋。这蛋能吃吗?问怎么办? 211大学厉害还是中西部高校综合实力提升工程厉害 实力碾压211的八所普通大学 以省份冠名的大学介绍 一年级语文听课记录 2015年宁夏二级建造师报考需要提供什么资料? 蓟门里南门到圆明园公园南门公交车 ...的微分公式为C*(du/dt),那么电容电压的积分公式是怎么推导出来的求过... 谁帮我取个家族名字啊,名字是:紫天 麻烦在后面想个有花字的名字