设计并开发一个简易的学生成绩管理信息系统 5

本系统具有以下三种功能:学生信息的输入(姓名,学号,成绩)、按成绩从高到低排序、所有学生成绩的打印。其中学生的信息包括:学号(字符串),姓名(字符串),成绩(整型)。高级... 本系统具有以下三种功能:
学生信息的输入(姓名,学号,成绩)、按成绩从高到低排序、所有学生成绩的打印。
其中学生的信息包括:学号(字符串),姓名(字符串),成绩(整型)。
高级功能(可选):增加文件操作,可以考虑将数据保存在硬盘上,每次运行先从硬盘读取上次已经录入的所有信息。
实验环境:TC2.0或VC++6.0
大哥,你的程序功能有点太强了,我看不懂啊,而且我也用不到啊
展开
 我来答
bpkdww
2011-01-14 · TA获得超过1800个赞
知道小有建树答主
回答量:1140
采纳率:100%
帮助的人:292万
展开全部
系统功能分析是在系统开发的总体任务的基础上完成。本系统需要完成的功能主要有9部分
1、登录模块:具有不同权限的管理人员可以通过用户名和密码登录系统,进入主界面。
2、学生成绩查询模块:按操作员输入的编号、姓名能以查询一个至多个学生的学生记录,并可打印存档。
3、学生成绩录入模块:录入学生成绩信息,输入完成后,将数据存盘。
4、学生成绩修改模块:对已存档的学生进行日常管理,如修改学生成绩、增加、删除等基本操作。
5、学生成绩统计分析模块:学生成绩报表,并给出分析报告。
6、用户管理模块:赋予高级管理者以增加、删除、修改普通管理员的权限。赋予普通管理员修改密码的权限。
7、系统备份模块:对系统的所有文件做备份,当系统文件丢失或损坏时可以对系统进行恢复,避免损失。
8、系统帮助模块:简单介绍本系统各模块的使用方法。
9、退出系统模块:退出系统返回WIDNOWS界面。
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
深圳市校管家教育科技有限公司_
2024-02-23 广告
选择培训学校管理系统,需要考虑多方面因素,如系统功能。培训学校管理系统实现了动态的网络化管理,提高了各职能部门的协同办公效能。培训学校管理系统是针对培训学校的管理和教学特点而设计的高效协同工作平台和优秀的综合管理系统。具体费用不是一定的,和... 点击进入详情页
本回答由深圳市校管家教育科技有限公司_提供
lzp4881
2011-01-13 · TA获得超过2394个赞
知道大有可为答主
回答量:2825
采纳率:0%
帮助的人:3012万
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
表单大师
2024-11-14 · 百度认证:表单大师官方账号
表单大师
人人可用的表单设计、数据收集和管理工具; 高效办公,零代码搭建企业管理系统; 对外营销,对内管理,一套工具就够了;
向TA提问
展开全部

其实不需要编写代码也能开发一个简易的学生成绩管理系统。

只需要用到表单大师表单大师这款软件就可以快速实现,

第一步:进入表单大师后台,创建学生成绩表,插入姓名、学号、学科分数等字段。

创建表单

第二步:设置公开查询

在规则页面点击新建查询,这里可以设置查询条件,例如学生只有输入正确的学号以及姓名才能查看到自己的成绩。

查询成绩

第三步:导入数据

在表单大师后台可以将学生成绩以excel表的形式导入进来,导入的数据可以随时进行增删改查等操作。

导入数据

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
来自美国迷人的阿拉蕾
2011-01-14 · TA获得超过2896个赞
知道小有建树答主
回答量:338
采纳率:0%
帮助的人:179万
展开全部
#include<iostream>
#include<fstream>
#include<string>
#include<conio.h>
#include<windows.h>
using namespace std;
#define PATH "d:\\StudentFile.txt"

class student
{
private:
char Number[20];
char Name[40];
int Math; int English; int Chinese;

public:
void GetInformation()
{
cout<<cout<<"学号\t\t姓名\t数学\t英语\t语文"<<endl;
cout<<"\t";
cin>>Number>>Name>>Math>>English>>Chinese;
}
void ShowInformation()
{
cout<<Number<<"\t"<<Name<<"\t"<<Math<<"\t"<<English<<"\t"<<Chinese<<endl;
}

char *SetNumber(){ return Number; }

char GetNumber(char number[])
{
if(strcmp(Number,number)==0)
return 1;
return 0;
}
};

struct linklist
{
student *data;
linklist *next;
};
int N=0; //定义当前程序中共有多少学生
linklist *HEAD=NULL,*REAR=NULL;
void readin() //从文件中读取已经存储的学生数据;
{
ifstream in(PATH); /*PATH为存档文件路径*/
in.read((char*)(&N),sizeof(int)); //文件开始的前4个字节记录这当前文件中共有多少个学生信息,所以先将它读入程序
for(int i=0;i<N;i++)
if(i==0) //如果当前是第一个学生信息
{
HEAD=REAR=new linklist;
HEAD->next=NULL;
HEAD->data=new student;
in.read((char *)(HEAD->data),sizeof(student)); //读入学生信息
}
else
{ //头插法建立学生信息链表
linklist *p=new linklist;
REAR->next=p;
REAR=p;
p->next=NULL;
REAR->data=new student;
in.read((char *)(REAR->data),sizeof(student)); //读入学生信息
}
in.close();
}
void savefile() //存档
{
ofstream out(PATH);
out.write((char *)&N,sizeof(int)); //首先把多少个学生写进文件
for(int i=0;i<N;i++)
{
out.write((char *)(HEAD->data),sizeof(student)); //将学生信息入档

delete HEAD->data; //删除HEAD->data指向的学生

linklist *p=HEAD->next; //删除linklinklist节点
delete HEAD;
HEAD=p;
}

out.close();
}
void newstudent() //新建学生
{
linklist *p;
if(HEAD==NULL)
{
HEAD=REAR=new linklist;
HEAD->data=new student;
HEAD->data->GetInformation();
HEAD->next=NULL;
}
else
{
REAR->next=p=new linklist;
p->data=new student;
p->data->GetInformation();
p->next=NULL;
REAR=p;
}

}
void shengxu() //对学生学号升序排序
{
if(N<2) //如果学生数小于2,不用排了,直接返回
return ;
linklist *p,*k; /*k是前一个节点,P是后一个*/
for(int i=1,j;i<N;i++)
{
for(p=HEAD->next,k=HEAD,j=0;j<N-i;p=p->next,k=k->next,j++)
if(strcmp(p->data->SetNumber(),k->data->SetNumber())<0)
{
student *s=p->data;
p->data=k->data;
k->data=s;
}
}
}
void jiangxu()
{
if(N<2) //如果学生数小于2,不用排了,直接返回
return ;
linklist *p,*k; /*k是前一个节点,P是后一个*/
for(int i=1,j;i<N;i++)
{
for(p=HEAD->next,k=HEAD,j=0;j<N-i;p=p->next,k=k->next,j++)
if(strcmp(p->data->SetNumber(),k->data->SetNumber())>0)
{
student *s=p->data;
p->data=k->data;
k->data=s;
}
}
}

void InsertUp()//插入(保持升序排列)
{
linklist *s;
s=new linklist;
s->data=new student;
s->data->GetInformation();
s->next=NULL;
s->next=HEAD;
HEAD=s;
shengxu();
N++;
}
void InsertDown()//插入(保持降序排列)
{
linklist *s;
s=new linklist;
s->data=new student;
s->data->GetInformation();
s->next=NULL;
s->next=HEAD;
HEAD=s;
jiangxu();
N++;
}
void Delete(char num[])//删除
{
linklist *p,*k;
k=p=HEAD;
while(p)
{
if(strcmp(p->data->SetNumber(),num)==0)
break;
k=p;
p=p->next;
}
if(p==HEAD)
{
HEAD=HEAD->next;
delete p->data;
delete p;
N--;
}
else if(p==NULL)
{
cout<<"输入有误。请重新输入。";
}
else
{
k->next=p->next;
delete p->data;
delete p;
N--;
}

}
void Revise(char num[])//修改(修改完成后需要再进行一下升序或降序排列)
{
linklist *p;
p=HEAD;
while(p)
{
if(strcmp(p->data->SetNumber(),num)==0)
break;
p=p->next;
}
p->data->GetInformation();
p->data->ShowInformation();
}

void screen(int x)
{
if(x==0)
{
cout<<endl<<endl<<endl<<endl;
cout<<" 欢迎进入小型学生信息管理系统"<<endl;
}
else if(x==1)
{
system("cls");
cout<<"\t 学生信息管理系统 "<<endl<<endl;
cout<<"\t*************************************************************"<<endl;
cout<<"\t* 1 、新建学生信息 *"<<endl;
cout<<"\t* 2 、显示已存学生信息 *"<<endl;
cout<<"\t* 3 、删除学生信息 *"<<endl;
cout<<"\t* 4 、添加学生信息 *"<<endl;
cout<<"\t* 5 、修改学生信息 *"<<endl;
cout<<"\t* 6 、对学生信息按学号升序排列 *"<<endl;
cout<<"\t* 7 、对学生信息按学号降序排列 *"<<endl;
cout<<"\t* 8 、退出 * "<<endl;
cout<<"\t*************************************************************"<<endl;
cout<<endl<<"\t"<<"请输入:";

}
}
void Confirm()
{
char x;
cout<<"是否继续(Y/N):";
cin>>x;
if(x=='Y' || x=='y')
return ;
else if(x=='N' || x=='n')
{
savefile();
exit(0);
}
}
void cometrue(int x)
{
switch(x)
{
case 1:
{
int people;
cout<<"请输入需要新建的学生人数:";
cin>>people;
for(int i=0;i<people;i++,N++)
{
newstudent();
}
Confirm();
break;
}
case 2:
{
readin();
linklist *p;
p=HEAD;
cout<<"学号\t\t姓名\t数学\t英语\t语文"<<endl;
while(p!=NULL)
{
p->data->ShowInformation();
p=p->next;
}
//savefile();
Confirm();
break;
}
case 3:
{
// readin();
char num[20];
cout<<"请输入需要删除的学生的学号:";
cin>>num;
Delete(num);
Confirm();
break;
}
case 4:
{
int m;
cout<<"请输入插入后保持学生信息升序排列还是降序排列"<<endl;
cout<<"\t\t\t\t1、保持升序排列"<<endl<<"\t\t\t\t2、保持降序排列"<<endl;
cin>>m;
if(m==1)
InsertUp();
else if(m==2)
InsertDown();
Confirm();
break;
}
case 5:
{
char num[20];
cout<<"请输入需要修改的学生的学号:";
cin>>num;
Revise(num);
Confirm();
break;
}
case 6:
{

shengxu();
Confirm();
break;
}
case 7:
{

jiangxu();
Confirm();
break;
}
case 8:
{
char answer;
cout<<"是否存档(Y/N)"; cin>>answer;
if(answer=='Y' || answer=='y')
{
savefile();
exit(0);
}
else if(answer=='N' || answer=='n')
exit(0);
break;
}
}
}

int main()
{
int choose;
screen(0);
Sleep(1200);
while(1)
{
screen(1);
cin>>choose;
cometrue(choose);
}
return 0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式