学生个人信息管理系统代码详解

本文详细介绍了学生个人信息管理系统的代码实现,包括录入、查询、排序、插入、浏览、修改和删除等功能。通过123.h、vvv.cpp及main.cpp等文件,实现了按姓名、学号和成绩的查询及排序操作。
摘要由CSDN通过智能技术生成
具体代码:
123.h:
#include <stdio.h>
struct STUDENT
{
    char Num[30];/*学生学号*/
    char Name[30];/*学生姓名*/
    char className[30];/*班级名称*/
    char telNumber[30];/*学生手机号*/
	char email[30];/*学生邮箱*/
	char course[30];/*课程信息*/
	int score;/*成绩*/
};
typedef struct LNode
{
struct STUDENT data;
struct LNode* next;
}LNode,*Linklist;
int  Initlist(Linklist *L);//初始化单链表
int  Creatlist(Linklist L);//头插法生成单链表
void Display(Linklist L);//显示学生信息
int  SearchNum(Linklist L,char Num[30]);//学号查询
int  SearchName(Linklist L,char Name[30]);//姓名查询
void SortNum(Linklist L);//编号排序
void SortName(Linklist L);//姓名排序
void SortScore(Linklist L);//成绩排序
int  Insert(Linklist L,char Num[30]);//插入信息
int Del(Linklist L,char Num[30]);//按学号删除
int Alter(Linklist L,char Num[30]);//更改信息
 
vvv.cpp
#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>
#include <string.h>
#include "123.h"
int Initlist(Linklist *L)//初始化线性表
{
	(*L)=(Linklist)malloc(sizeof(LNode));
    if(!(*L))
    return (0);
    (*L)->next=NULL;
    return true;
}
/*************************************************************************************** 
*功能描述:运用头插法建立单链表
*输入参数:无
*输出参数:无  
*返回值:无
*其他说明:消息字段之间用分号(;)隔离  
***************************************************************************************/  
int Creatlist(Linklist L)//头插法生成单链表
{
	    Linklist s,r;
		s=(Linklist )malloc(sizeof(LNode));
		if(!s)
		{
			return 0;
		}
		else
		{
            printf("请输入学生的个人信息\n");
			printf("学号:   \n");
			scanf("      %s",s->data.Num);
            printf("姓名:   \n");
			scanf("      %s",s->data.Name);
		    printf("班级:   \n");
			scanf("      %s",s->data.className);
	     	printf("手机号: \n");
			scanf("      %s",s->data.telNumber);
	    	printf("邮箱:   \n");
			scanf("      %s",s->data.email);
			printf("专业课程:   \n");
			scanf("      %s",s->data.course);
			printf("数学成绩:   \n");
			scanf("      %d",&s->data.score);		  
		}
	    s->next=L->next;
		L->next=s;
	    return true;
}
/*************************************************************************************** 
*功能描述:显示学生的信息
*输入参数:无
*输出参数:无  
*返回值:无
*其他说明:消息字段之间用分号(;)隔离  
***************************************************************************************/  
void Display(Linklist L)//显示学生信息
{
	Linklist p;
	char flat=0;
	while(p)
	{
		printf("学号\t姓名\t班级\t手机号\t邮箱\t专业课程\t成绩\n");
	for(p=L->next;p;p=p->next)
	{
    printf("%s\t%s\t%s\t%s\t\t%s\t %s\t%d\n",p->data.Num,p->data.Name,p->data.className,p->data.telNumber,p->data.email,p->data.course,p->data.score);
	flat=1;
	} 
	}
	if(!flat)
	{
		printf("无法显示学生的信息,请进入其他功能区 \n");
	}
}
/*************************************************************************************** 
*功能描述:按学号进行查询
*输入参数:无
*输出参数:无  
*返回值:无
*其他说明:消息字段之间用分号(;)隔离  
***************************************************************************************/  
int SearchNum(Linklist L,char Num[20])//学号查询
{
	LNode *p;
	char flat=0;
	p=L;
	while(p)
	{
		if(p!=NULL)
		{
		if(strcmp(p->data.Num,Num)==0)
		  {
			printf("学号:     %s\n",p->data.Num);
            printf("姓名
学生信息管理系统# include # include # include #include #include using namespace std; struct Student1 { char *num;//学号 char *subnum;//课程编号 char *subname;//课程编号 char *grade;//学分 char *score1;//平时成绩 char *score2;//实验成绩 char *score3;//卷面成绩 float m;//综合成绩 float n;//实得学分 Student1 *next; };//学号 姓名 性别 宿舍号码 电话号码 struct Student2 { char *num;//学号 char *name;//姓名 char *sex;//性别 char *roomnum;//宿舍号码 char *tel;//电话号码 Student2 * next; }; struct InfList { Student2* head; int size; }; struct CourseList { Student1 * head; int size; }; InfList create2()//创建一个空链表 { InfList list; list.head=0; list.size=0; return list; } CourseList create1()//创建一个空链表 { CourseList list; list.head = 0; list.size = 0; return list; } void deleteAll1(Student1 * p)//cc { delete []p->num; delete []p->grade; delete []p->subnum; delete []p->subname; } void deleteAll(Student2* p1)//in { delete []p1->name; delete []p1->num; delete []p1->roomnum; delete []p1->sex; delete []p1->tel; } void removeAll1 (CourseList & list) { Student1 *p1; while(list.head != NULL) { p1 = list.head; list.head = list.head->next; delete p1; } list.size = 0; } void removeAll (InfList & list) { Student2 *p1; while(list.head != NULL) { p1 = list.head; list.head = list.head->next; delete p1; } list.size = 0; } double getM(char* a,char *b,char *c)//计算综合成绩 { double m; double a1=atof(a); double b1=atof(b); double c1=atof(c); if(!strcmp(b,"-1")) { m=a1*(0.3)+c1*(0.7); return m; } else { m=a1*(0.15)+b1*(0.15)+c1*(0.7); return m; } } double getN(char *a,double b)//计算实得学分 { double n; double a1=atof(a); switch(int(b)/10) { case 10: case 9:n=a1*1;return n;break; case 8:n=a1*(0.8);return n;break; case 7:n=a1*(0.75);return n;break; case 6:n=a1*(0.6);return n;break; default:n=0;return n; } } CourseList LoadData1 (CourseList & list) //将成绩数据读入数组,动态变量管理 { list=create1(); ::ifstream infile("b.txt",ios::in|ios::nocreate);//打开成绩文件 if(!infile) { cout<<"不能打开文件:b.txt"<>buff; if(infile.eof()) break; p1->num=new char[strlen(buff)+1]; strcpy(p1->num,buff); infile>>buff; p1->subnum=new char[strlen(buff)+1]; strcpy(p1->subnum,buff); infile>>buff; p1->subname=new char[strlen(buff)+1]; strcpy(p1->subname,buff); infile>>buff; p1->grade=new char[strlen(buff)+1]; strcpy(p1->grade,buff); infile>>buff; p1->score1=new char[strlen(buff)+1]; strcpy(p1->score1,buff); infile>>buff; p1->score2=new char[strlen(buff)+1]; strcpy(p1->score2,buff); infile>>buff; p1->score3=new char[strlen(buff)+1]; strcpy(p1->score3,buff); p1->m=getM(p1->score1,p1->score2,p1->score3); p1->n=getN(p1->grade,p1->m); p1->next=NULL; if (list.head==0) list.head=p1; else p2->next=p1; p2=p1; n++; } list.size=n; infile.close(); return list; } InfList LoadData (InfList & list) //将基本信息数据读入数组,动态变量管理 { list=create2(); ::ifstream infile("a.txt",ios::in|ios::nocreate);//打开信息文件 if(!infile) { cout<<"不能打开文件:a.txt"<>buff; if(infile.eof()) break; p1->num=new char[strlen(buff)+1]; strcpy(p1->num,buff); infile>>buff; p1->name=new char[strlen(buff)+1]; strcpy(p1->name,buff); infile>>buff; p1->sex=new char[strlen(buff)+1]; strcpy(p1->sex,buff); infile>>buff; p1->roomnum=new char[strlen(buff)+1]; strcpy(p1->roomnum,buff); infile>>buff; p1->tel=new char[strlen(buff)+1]; strcpy(p1->tel,buff); p1->next=NULL; if (list.head==0) list.head=p1; else p2->next=p1; p2=p1; n++; } list.size=n; return list; infile.close(); } char * getChar(const char * sen) { cout<<sen<>c; while(!cin.good()) { cin.clear(); cin.getline(buffer, 80); cout<>c; } return c; } int getInt( const char * msg) { cout<<msg<>n; while(!cin.good()) { cin.clear(); cin.getline(buffer, 80); cout<>n; } return n; } void print(CourseList &list;)//输出所有数据 { system("cls");//清屏 LoadData1(list); cout<<setiosflags(ios::left); cout<<"学生成绩录入:"<<endl<<'\n'; Student1 *p = list.head; cout<<"学号"<<setw(10)<<"课程编号"<<setw(10)<<"课程名称"<<setw(9)<<"学分"; cout<<setw(8)<<"平时成绩"<<setw(10)<<"实验成绩"<<setw(10)<<"卷面成绩"; cout<<setw(10)<<"综合成绩"<<setw(10)<<"实得学分"<<endl; while (p!= NULL) { cout<<setw(3)<num<<setw(10)<subnum<<setw(12)<subname<<setw(9)<grade; cout<<setw(8)<score1<<setw(10)<score2<<setw(10)<score3; cout<<setw(10)<m<<setw(10)<n<next; } cout<<"size(学生个数)="<<list.size/3<<endl; cout<next; deleteAll1(p1); } removeAll1(list); } void Numprint(InfList & list) { LoadData(list); char num[20]; int m=0; strcpy(num,getChar("请输入学号:")); cout<num,num)) { cout<<"学号"<<setw(8)<<"宿舍号"<<setw(8)<<"姓名"<<setw(8)<<"性别"<<setw(8)<<"电话号"<<endl; cout<<setw(4)<num<<setw(8)<roomnum<<setw(8)<name<<setw(8)<sex<<setw(8)<tel<next; } if(m==0) { cout<<"未找到学生学号"<<num<<endl; cout<<endl; if(getInt("是否继续查询:(1/0)")==1) Numprint(list); cout<<endl; return; } cout<<endl; if(getInt("是否继续查询:(1/0)")==1) Numprint(list); cout<next; deleteAll(p1); } removeAll(list); } void Nameprint(InfList & list) { LoadData (list); char name [20]; int m=0; strcpy(name,getChar("输入姓名:")); Student2 * p = list.head; for(int i = 0; p != NULL; i++) { if (!strcmp(p->name,name)) { cout<<"学号"<<setw(8)<<"宿舍号"<<setw(8)<<"姓名"<<setw(8)<<"性别"<<setw(8)<<"电话号"<<endl; cout<<setw(4)<num<<setw(8)<roomnum<<setw(8)<name<<setw(8)<sex<<setw(8)<tel<next; } if(m==0) { cout<<"未找到学生"<<name<<'\n'; cout<<endl; if(getInt("是否继续查询:(1/0)")==1) Nameprint(list); cout<<endl; return; } cout<<endl; if(getInt("是否继续查询:(1/0)")==1) Nameprint(list); cout<next; deleteAll(p1); } removeAll(list); } void Rnumprint(InfList & list) { LoadData (list); char rnum [20]; int m=0; strcpy(rnum,getChar("输入宿舍号:")); Student2 * p = list.head; for(int i = 0; p != NULL; i++) { if (!strcmp(p->roomnum,rnum)) { cout<<"学号"<<setw(8)<<"宿舍号"<<setw(8)<<"姓名"<<setw(8)<<"性别"<<setw(8)<<"电话号"<<endl; cout<<setw(4)<num<<setw(8)<roomnum<<setw(8)<name<<setw(8)<sex<<setw(8)<tel<next; } if(m==0) { cout<<"未找到宿舍号"<<rnum<<'\n'; cout<<endl; if(getInt("是否继续查询:(1/0)")==1) Rnumprint( list); cout<<endl;return; } cout<<endl; if(getInt("是否继续查询:(1/0)")==1) Rnumprint(list); cout<next; deleteAll(p1); } removeAll(list); } void NumPrint(CourseList & list) { LoadData1(list); char num[20]; int s=0; double sum=0; strcpy(num,getChar("请输入学号:")); cout<num,num)) { if(s==0) { cout<<' '<<"学号"<<setw(10)<<"课程编号"<<setw(9)<<"课程名称"<<setw(10)<<"综合成绩"<<setw(10)<<"实得学分"<<endl; } cout<<setw(4)<num<<setw(10)<subnum<<setw(10)<subname<<setw(10)<m<<setw(10)<n<n; } p=p->next; } cout<<"共修:"<<s<<"科,"<<"实得总学分为:"<<sum<<endl; if(s==0) { cout<<"未找到学生学号"<<num<<endl; if(getInt("是否继续查询:(1/0)")==1) NumPrint(list); cout<<endl; return; } cout<<endl; if(getInt("是否继续查询:(1/0)")==1) NumPrint(list); cout<next; deleteAll1(p1); } removeAll1(list); } int Gochoice () { system("cls"); cout<<" \n\n"; cout<<" 学 生 基 本 信 息 查 询"; cout<<"\n\n \n\n"; cout<< "输入命令编号:\n\n"; cout<<" 1. 学号查询\n"<<endl; cout<<" 2. 姓名查询\n"<<endl; cout<<" 3. 宿舍号查询\n"<<endl; cout<<" 0. 返回菜单\n"<<endl; return getInt("选择命令:"); } void GetAll() { CourseList list; print(list); } void LookInf()//查询学生信息 { int choice; InfList list1; while((choice = Gochoice()) != 0) { switch(choice) { case 1: Numprint(list1); break; case 2: Nameprint(list1); break; case 3: Rnumprint(list1); break; default:cout<<"输入命令不存在\n"; } } } void LookGrade()//查询成绩 { CourseList list; NumPrint(list); } void Remove1 (InfList &list;, const int index)//删除a.txt的数据 { system("cls"); cout<<setiosflags(ios::left); if (list.size == 0 || index list.size) return ; if (index == 0) { list.size--; Student2 *p = list.head; list.head = list.head->next; cout<<"删除文件a.txt:"<<endl; cout<<' '<<"学号"<<setw(10)<<"姓名"<<setw(10)<<"性别"<<setw(10)<<"宿舍号"<<setw(10)<<"电话"<<endl; cout<<setw(4)<num<<setw(10)<name<<setw(10)<sex<<setw(10)<roomnum<<setw(10)<tel<<endl<<'\n'; delete p; return ; } Student2 *p1 = list.head, *p2 = p1; for(int i = 0; i next; } list.size--; p1->next = p2->next; cout<<"删除文件a.txt:"<<endl; cout<<"学号"<<setw(8)<<"姓名"<<setw(10)<<"性别"<<setw(10)<<"宿舍号"<<setw(10)<<"电话"<<endl; cout<<setw(4)<num<<setw(10)<name<<setw(10)<sex<<setw(10)<roomnum<<setw(10)<tel<<endl<<'\n'; delete p2; } void Remove2 (CourseList & list2, const int index) { cout<<setiosflags(ios::left); if (list2.size == 0 || index = list2.size) return ; if (index == 0) { list2.size--; Student1 *p = list2.head; list2.head = list2.head->next; cout<<"删除文件b.txt:"<<endl; cout<<"学号"<<' '<<"课程编号"<<' '<<"课程名称"<<' '<<"综合成绩"<<' '<<"实得学分"<<endl; cout<<setw(4)<num<<setw(10)<subnum<<setw(10)<subname<<setw(10)<m<<setw(10)<n<<endl<<'\n'; deleteAll1(p); delete p; return ; } Student1 *p1 = list2.head, *p2 = p1; for(int i = 0; i next; } list2.size--; p1->next = p2->next; cout<<"删除文件b.txt:"<<endl; cout<<"学号"<<' '<<"课程编号"<<' '<<"课程名称"<<' '<<"综合成绩"<<' '<<"实得学分"<<endl; cout<<setw(4)<num<<setw(10)<subnum<<setw(10)<subname<<setw(10)<m<<setw(10)<n<<endl<num,num)==0) return i; p=p->next; } return -1; } int SearchList( CourseList & list, char * num) { Student1 *p = list.head; for(int i = 0; p != NULL; i++) { if (strcmp(p->num,num)==0) return i; p = p -> next; } return -1; } void DeleteOne()//删除函数 { cout<<setiosflags(ios::left); CourseList list1;//b.txt成绩 InfList list;//a.txt LoadData (list); LoadData1(list1); Student1 * pp=list1.head; Student2 * p=list.head; char num [20]; int sen,lin; strcpy(num,getChar("输入学号:")); sen=SearchData(list,num); if(sen==-1) cout<<"未找到学生"<<num; Remove1(list,sen); for(;;) { lin=SearchList(list1,num); if(lin==-1) break; Remove2(list1,lin); } ::ofstream outfile("a.txt"); if (!outfile ) { cout << "不能打开目的文件:"<<"a.txt"<<'\n'; return; } if((list.size)!=0) outfile<<"学号"<<'\t'<<"姓名"<<'\t'<<"性别"<<'\t'<<"宿舍号码"<<'\t'<<"电话号码"<<'\n'; else cout<<"文件已空"<<endl; Student2 * p1=list.head; while(p1!=NULL) { outfile<num<<'\t'<name<<'\t'<sex<<'\t'<roomnum<<'\t'<<'\t'<tel<next; } outfile.close(); ::ofstream outfile2("b.txt",ios::out); if (!outfile2 ) { cout << "不能打开目的文件:"<<"b.txt"<<'\n'; return; } if((list1.size)!=0) { outfile2<<"学号"<<' '<<"课程编号"<<' '<<"课程名称"<<' '<<"学分"<<' '<<"平时成绩"<<' '<<"实验成绩"; outfile2<<' '<<"卷面成绩"<<' '<<"综合成绩"<<' '<<"实得学分"<<'\n'; } else cout<<"文件已空"<subname,"VC++")==0) { if(pp1->next==NULL) { outfile2<num<<setw(6)<subnum; outfile2<<setw(6)<<' '<subname<<setw(5)<<' '<grade<<setw(4)<<' '<score1; outfile2<<setw(7)<<' '<score2<<setw(7)<<' '<score3; } else { outfile2<num<<setw(6)<subnum; outfile2<<setw(6)<<' '<subname<<setw(5)<<' '<grade<<setw(4)<<' '<score1; outfile2<<setw(7)<<' '<score2<<setw(7)<<' '<score3<<'\n';} } else { outfile2<num<<setw(6)<subnum; outfile2<<setw(6)<<' '<subname<<' '<grade<<setw(4)<<' '<score1; outfile2<<setw(7)<<' '<score2<<setw(7)<<' '<score3<next; } outfile2.close(); cout<<endl; if(getInt("是否继续删除:(1/0)")==1) DeleteOne(); cout<next; deleteAll1(p1); } removeAll1(list1); while(list.head!=NULL) { Student2*p1; p1=list.head; list.head=list.head->next; deleteAll(p1); } removeAll(list); } CourseList sortM(CourseList & list)//综合成绩降序排序 { LoadData1(list); Student1 *p1,*p2; char * data1; float data2; int n; n=list.size; p1=list.head; if (n==0||n==1) return list; for(;p1->next!=NULL;p1=p1->next) { p2=p1->next; for(;p2!=NULL;p2=p2->next) { if (p1->mm) { data1=p1->num; p1->num=p2->num; p2->num=data1; data1=p1->subnum; p1->subnum=p2->subnum; p2->subnum=data1; data1=p1->subname; p1->subname=p2->subname; p2->subname=data1; data1=p1->grade; p1->grade=p2->grade; p2->grade=data1; data1=p1->score1; p1->score1=p2->score1; p2->score1=data1; data1=p1->score2; p1->score2=p2->score2; p2->score2=data1; data1=p1->score3; p1->score3=p2->score3; p2->score3=data1; data2=p1->m; p1->m=p2->m; p2->m=data2; data2=p1->n; p1->n=p2->n; p2->n=data2; } } } return list; } CourseList sortN(CourseList & list)//实得学分降序排序 { LoadData1(list); Student1 *p1,*p2; char * data1; float data2; int n; n=list.size; p1=list.head; if (n==0||n==1) return list; for(p1=list.head;p1->next!=NULL;p1=p1->next) { p2=p1->next; for(;p2!=NULL;p2=p2->next) { if (p1->nn) { data1=p1->num; p1->num=p2->num; p2->num=data1; data1=p1->subnum; p1->subnum=p2->subnum; p2->subnum=data1; data1=p1->subname; p1->subname=p2->subname; p2->subname=data1; data1=p1->grade; p1->grade=p2->grade; p2->grade=data1; data1=p1->score1; p1->score1=p2->score1; p2->score1=data1; data1=p1->score2; p1->score2=p2->score2; p2->score2=data1; data1=p1->score3; p1->score3=p2->score3; p2->score3=data1; data2=p1->m; p1->m=p2->m; p2->m=data2; data2=p1->n; p1->n=p2->n; p2->n=data2; } } } /*while(list.head!=NULL) { Student1*p1; p1=list.head; list.head=list.head->next; deleteAll1(p1); } removeAll1(list);*/ return list; } CourseList sortMM(CourseList & list)//综合成绩升序排序 { LoadData1(list); Student1 *p1,*p2; char * data1; float data2; int n; n=list.size; p1=list.head; if (n==0||n==1) return list; for(p1=list.head;p1->next!=NULL;p1=p1->next) { p2=p1->next; for(;p2!=NULL;p2=p2->next) { if (p1->m>p2->m) { data1=p1->num; p1->num=p2->num; p2->num=data1; data1=p1->subnum; p1->subnum=p2->subnum; p2->subnum=data1; data1=p1->subname; p1->subname=p2->subname; p2->subname=data1; data1=p1->grade; p1->grade=p2->grade; p2->grade=data1; data1=p1->score1; p1->score1=p2->score1; p2->score1=data1; data1=p1->score2; p1->score2=p2->score2; p2->score2=data1; data1=p1->score3; p1->score3=p2->score3; p2->score3=data1; data2=p1->m; p1->m=p2->m; p2->m=data2; data2=p1->n; p1->n=p2->n; p2->n=data2; } } } return list; } CourseList sortNN(CourseList & list)//实得学分升序排序 { LoadData1(list); Student1 *p1,*p2; char * data1; float data2; int n; n=list.size; p1=list.head; if (n==0||n==1) return list; for(p1=list.head;p1->next!=NULL;p1=p1->next) { p2=p1->next; for(;p2!=NULL;p2=p2->next) { if (p1->n>p2->n) { data1=p1->num; p1->num=p2->num; p2->num=data1; data1=p1->subnum; p1->subnum=p2->subnum; p2->subnum=data1; data1=p1->subname; p1->subname=p2->subname; p2->subname=data1; data1=p1->grade; p1->grade=p2->grade; p2->grade=data1; data1=p1->score1; p1->score1=p2->score1; p2->score1=data1; data1=p1->score2; p1->score2=p2->score2; p2->score2=data1; data1=p1->score3; p1->score3=p2->score3; p2->score3=data1; data2=p1->m; p1->m=p2->m; p2->m=data2; data2=p1->n; p1->n=p2->n; p2->n=data2; } } } /*while(list.head!=NULL) { Student1*p1; p1=list.head; list.head=list.head->next; deleteAll1(p1); } removeAll1(list);*/ return list; } void sortPrint (char * c,CourseList & list,char *cc)//输出实得学分排名 { system("cls"); Student1 * p = list.head; if (p==0) { cout<<"数据为空"<subname,c)&&!strcmp(cc,"实得学分")) { cout<<"第"<<n+1<<"名:"<<"学号:"<num<<'\t'<<"课程名称:"<subname<<'\t'<<"实得学分:"<n<subname,c)&&!strcmp(cc,"综合成绩")) { cout<<"第"<<n+1<<"名:"<<"学号:"<num<<'\t'<<"课程名称:"<subname<<'\t'<<"综合成绩:"<m<next; } if (n==0) cout<<"未找到"<<c<<'\n'; } int Select(){ cout<<"选择排序方式:"<<endl; cout<<" 1.升序"<<endl; cout<<" 2.降序"<<endl; cout<<" 0.退出"<<endl; return getInt("选择命令:"); } void Arrange1()//实得学分 { char str[3][10]={"大学物理","高等数学","VC++"}; char xf[]={"实得学分"}; int j=0; CourseList list1; char c[256]; strcpy(c,getChar("输入学科:")); for(int i=0;i<3;i++) { if (!strcmp(str[i],c)) j++; } if(j==0) cout<<"查无此学科"<<endl; else { int choice; while((choice= Select())!=0) { switch(choice) { case 1:sortPrint(c,sortNN(list1),xf);break; case 2:sortPrint(c,sortN(list1),xf);break; default:cout<<"输入命令不存在\n";cout<<"请重输:\n"<<endl;} } } if(getInt("是否继续排序:(1/0)")==1) Arrange1(); cout<next; deleteAll1(p1); } removeAll1(list1); } void Arrange2()//综合成绩 { char str[3][10]={"大学物理","高等数学","VC++"}; char zh[]={"综合成绩"}; int j=0; CourseList list1; char c[256]; strcpy(c,getChar("输入学科:")); for(int i=0;i<3;i++) { if (!strcmp(str[i],c)) j++; } if(j==0) cout<<"查无此学科"<<endl;//return; else { int choice; while((choice= Select())!=0) { switch(choice) { case 1:sortPrint(c,sortMM(list1),zh);break; case 2:sortPrint(c,sortM(list1),zh);break; default:cout<<"输入命令不存在\n"; cout<<"请重输:\n"<<endl; } } } if(getInt("是否继续排序:(1/0)")==1) Arrange2(); cout<next; deleteAll1(p1); } removeAll1(list1); } int enterChoice() { cout<<"\n\n"; cout<<" 学 生 信 息 管 理 系 统"; cout<<"\n\n\n\n"; cout<<"请输入命令编号:\n\n"; cout<<" 1. 学生成绩录入\n"; cout<<" 2. 学生信息查询\n"; cout<<" 3. 学生成绩查询\n"; cout<<" 4. 学生信息删除\n"; cout<<" 5. 实得学分排名\n"; cout<<" 6. 综合成绩排名\n"; cout<<" 0. 退出\n"; return getInt("选择命令:"); } void main() { int choice; while((choice = enterChoice()) != 0) { switch(choice) { case 1: GetAll();break; //学生成绩录入 case 2: LookInf(); system("cls"); break;//学生基本信息查询 case 3: LookGrade(); system("cls");break;//学生成绩查询 case 4: DeleteOne(); system("cls");break;//学生信息删除 case 5: Arrange1(); system("cls");break;//实得学分排名 case 6: Arrange2(); system("cls");break;//综合成绩排名 default:cout<<"输入命令不存在\n"; cout<<"请重输:\n"<<endl; } } }
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值