C++和C用顺序存储实现学生成绩管理系统

1 篇文章 0 订阅

运行程序显示如下菜单:

  按菜单提示输入相应数字完成规定的操作并显示输出处理结果 .

源程序代码及实验结果记录:

源代码:

#include<iostream>
#include<windows.h>
#include<string.h>
using namespace std;
#define MAXSIZE 30
#define OVERFLOW -1
#define ERROR 0
#define OK 1
typedef struct		//学生信息定义 
{
	char name[10];	//学生姓名 
	char num[20];	//学生学号 
	float score;	//学生成绩 
}Student;

typedef struct
{
	Student *elem;	//存储空间的基地址 
	int length;		//学生成绩管理系统当前学生人数 
}SqList;

int InitList(SqList &L)
{//创建线性表
	L.elem=new Student[MAXSIZE];//为顺序表分配一个大小为MAXSIZE的数组空间 
	if(!L.elem) exit(OVERFLOW);  //存储分配失败退出 
	L.length=0;					 //空表长度为0 
	return OK;
}

int ListInsert(SqList &L,int i,Student &e)
{//在顺序表L中第i个位置插入新的元素e,i值的合法范围是1<=i<=L.length+1 
	if((i<1)||(i>L.length+1)) return ERROR;//i值不合法 
	if(L.length==MAXSIZE) return ERROR;    //当前存储空间已满 
	for(int j=L.length-1;j>=i-1;i--)
	{
		L.elem[j+1]=L.elem[j];			   //插入位置之后的元素后移 
	}									    
	L.elem[i-1]=e;                         //将新元素e放入第i个位置
	++L.length;                            //表长加1 
	return OK;
}

int ListDelete(SqList &L,int i)
{//在顺序表L中删除第i个元素,i值的合法范围是1<=i<=L.length 
	if((i<1)||(i>L.length)) return ERROR;	 //i值不合法 
	for(int j=i;j<=L.length-1;j++)
	{
		L.elem[j-1]=L.elem[j];				//被删除元素之后的元素前移 
	}
	--L.length;                            //表长减1 
	return OK;
}

int ListLength(SqList L)
{//返回顺序表L中数据元素的个数 
	return L.length;
}

int LocateName(SqList L,Student &e)
{//在顺序表L中按姓名查找 
	for(int i=0;i<L.length;i++)
	{
		if(!strcmp(L.elem[i].name,e.name))
		{
			e=L.elem[i];
			return OK;						//查找成功
		}
	}
	return ERROR;							//查找失败,返回0 
}

int LocateNum(SqList L,Student &e)
{//在顺序表L中按学号查找 
	for(int i=0;i<L.length;i++)
	{
		if(!strcmp(L.elem[i].num,e.num))
		{
			e=L.elem[i];
			return OK;						//查找成功
		}
	}
	return ERROR;							//查找失败,返回0 
}

int GetElem(SqList L,int i,Student &e)
{//顺序表的取值 
	if((i<1)||(i>L.length)) return ERROR;	//i值不合理 
	else 
	{
		e=L.elem[i-1];						//取出第i个元素,存放在e中 
		return OK;
	}
}

int SortScore(SqList L)
{//成绩排序
	for(int i=0;i<L.length-1;i++)
	{
		for(int j=0;j<L.length-i-1;j++)
		{
			if(L.elem[j+1].score>L.elem[j].score)
			{
				Student temp=L.elem[j+1];
				L.elem[j+1]=L.elem[j];
				L.elem[j]=temp;
			}
		}
	}
	return OK;
}
int main()
{
	SqList L;
	Student student;
	bool flag=true;
	do
	{
		cout<<"\n~~~~~~~~学生成绩管理系统~~~~~~~~\n";
		cout<<"\t1---创建线性表\n"; 
		cout<<"\t2---插入新同学信息\n";
		cout<<"\t3---删除\n";
		cout<<"\t4---总人数\n";
		cout<<"\t5---按学号查找\n";
		cout<<"\t6---按姓名查找\n";
		cout<<"\t7---成绩排序\n";
		cout<<"\t8---显示所有学生信息\n";
		cout<<"\t9---退出\n";
		cout<<"\t请输入所要执行程序前对应序号:";
		int index;
		cin>>index;
		system("cls");
		switch(index)
		{
			case 1:
			if(InitList(L)) cout<<"\n创建成功!\n";
			break;
			case 2:
			int insert;
			cout<<"请输入您所要插入的位置:";
			cin>>insert;
			cout<<"请输入您所要插入同学的姓名:";
			cin>>student.name;
			cout<<"请输入您所要插入同学的学号:";
			cin>>student.num;
			cout<<"请输入您所要插入同学的成绩:";
			cin>>student.score;
			if(ListInsert(L,insert,student)) cout<<"\n插入成功!\n";
			else cout<<"\n插入失败,请重新输入正确的插入位置!\n"; 
			break;
			case 3:
			int del;
			cout<<"请输入您所要删除的位置:";
			cin>>del;
			if(ListDelete(L,del)) 	cout<<"\n删除成功!\n";
			else cout<<"\n删除失败,请重新输入正确的删除位置!\n"; 
			break;
			case 4: 
			cout<<"\n总人数为"<<ListLength(L)<<endl;
			break;
			case 5:
			cout<<"请输入您所要查找的学生学号:";
			cin>>student.num;
			if(LocateNum(L,student)) 
			{
				cout<<"\n查找成功!\n";
				cout<<"学生姓名:"<<student.name<<endl;
				cout<<"学生学号:"<<student.num<<endl;
				cout<<"学生分数:"<<student.score<<endl;
			}
			else cout<<"\n系统中无记录\n";
			break;
			case 6:
			cout<<"请输入您所要查找的学生姓名:";
			cin>>student.name;
			if(LocateName(L,student)) 
			{
				cout<<"\n查找成功!\n";
				cout<<"学生姓名:"<<student.name<<endl;
				cout<<"学生学号:"<<student.num<<endl;
				cout<<"学生分数:"<<student.score<<endl;
			}
			else cout<<"\n系统中无记录\n";
			break;
			case 7:
			if(SortScore(L)) cout<<"\n成绩排序为:\n";
			cout<<"序号\t\t姓名\t\t学号\t\t成绩\n";
			for(int i=1;i<=L.length;i++)
			{
				GetElem(L,i,student);
				cout<<i<<'\t'<<'\t'<<student.name<<'\t'<<'\t'<<student.num<<'\t'<<student.score<<endl;
			}
			break;
			case 8:
			cout<<"\n所有学生信息\n";
			cout<<"序号\t\t"<<"姓名\t\t"<<"学号\t\t"<<"成绩"<<endl;
			for(int i=1;i<=L.length;i++)
			{
				GetElem(L,i,student);
				cout<<i<<'\t'<<'\t'<<student.name<<'\t'<<'\t'<<student.num<<'\t'<<student.score<<endl;
			}
			break;
			case 9:
			flag=false;
			cout<<"\n谢谢使用!\n"; 
			break;
			default:cout<<"\n请输入正确的序号!\n"; 
		}
	}while(flag);
}

C语言只需要改下头文件和输入输出就可以了

相当不错的一个成绩管理系统 #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; }
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值