C语言学生信息管理系统

要求:
用的是结构体 struct
求有录入、显示、查找(按学号或姓名)、删除和退出功能
简单的,不要太复杂了,用C编写
涉及到的信息:姓名,学号,年龄,班级,专业 ,不需要成绩什么的,界面什么的无所谓,尽量简单明了
最核心的是要有文件保存,把数据保存到文本当中。
最好不要用链表呀啥的我还不会链表,看不懂啊
#include<stdio.h> 
#include<string.h> 
#include<stdlib.h> 
#include<conio.h> 

#define max 20 

typedef struct student //学生 

char sno[max]; // 学号 
char sname[max]; //姓名 
char sex[max]; 坦巧塌//性别 
char age[max]; //年龄 
char depart[max]; //系 
char classs[max]; //班 
char grade[max]; //年级 

struct student* next; 
} student; 

student* head; 

int LogOn() //登录模块,已实现输入密码不回显,如果中途发现输错某几位,可退格键重输 

char username[max],password[max]; 
printf("\n请输入用户名:"); 
scanf("%s",username); 
printf("\n请输入密码(最多15位):"); 

//开始以不回显且支持退格方式获取输入密码 
int i=0; 
while((i>=0)&&(password[i++]=getch())!=13)//条件i>=0是用于限制退格的范围 

if(password[i-1]=='\b')//对退格键的处理 

printf("%c%c%c",'\b','\0','\b'); 
i=i-2; 

else 
printf("*"); 

password[--i]='\0'; 

//已获取密码。验证用户身份 
if(!strcmp(username,"zhang")&&!strcmp(password,"8147086")) 

printf("\n登录成功!"); 
return 1; 

else  
return 0; 



void 宽虚regist() 

char ch; 
student *s,*ptr; //s用来建新结点,ptr用来暂存头结点 

do 


s=(student*)malloc(sizeof(student)); // 新建一个学生结点 

printf("\n开始注册..."); //开始注册 
printf("\n请输入该学生的学号:"); 
scanf("%s",s->sno); 
printf("\n请输入该学生的姓名:"); 
scanf("%s",s->sname); 
printf("\n请输入该学生的性别:"); 
scanf("%s",s->sex); 
printf("\n请输入该学生的年龄:"); 
scanf("%s",s->age); 
printf("\n请输入该学生的系:"); 
scanf("%s",s->depart); 
printf("\n请输入该学生所在的班:"); 
scanf("%s",s->classs); 
printf("\n请输入该学生所在的年级"); 
scanf("%s",s->grade); 

ptr=head; 
head=s;//将新结点插入队头 
s->next=ptr; 

fflush(stdin); 
printf("\n请问是否继续注册?(Y/N)"); 
scanf("%c",&ch); 
}while(ch=='Y'||ch=='y'); 

return; 
} 让圆

void ElePrint(char str[]) //输出单个元素 

if(str==NULL) exit(0); 
printf("%s",str); 
for(unsigned int i=0;i<12-strlen(str);i++) printf(" ");//为了对齐输出,需插入一些空格 
return; 


int LinePrint(student *ptr) //输出一行 

if(ptr==NULL) //检查传进来的指针 
return 0; 

printf("\n"); 
ElePrint(ptr->sno); 
ElePrint(ptr->sname); 
ElePrint(ptr->age); 
ElePrint(ptr->sex); 
ElePrint(ptr->depart); 
ElePrint(ptr->classs); 
ElePrint(ptr->grade); 

return 1; 


void print() //输出全部学生信息 

student *ptr=head; 
printf("\n学号 姓名 年龄 性别 系 班 年级 "); 
while(ptr) 

LinePrint(ptr); 
ptr=ptr->next; 

printf("\n"); 
return; 

void search()//查询模块 

int method;//查询方式 
char no[max],name[max],departm[max],clss[max],grades[max]; //用来接收查询关键字 
while(1) 

printf("\n请选择查询方式"); 
printf("\n1.按学号查询"); 
printf("\n2.按姓名查询"); 
printf("\n3.按所在系查询"); 
printf("\n4.按所在班级查询"); 
printf("\n5.按所在年级查询"); 
printf("\n6.打印全部学生信息"); 
printf("\n7.返回主菜单\n"); 

scanf("%d",&method); 

student *p=head,*temp; 

switch(method) 

case 1:  
printf("\n请输入要查询的学号:"); 
scanf("%s",no);  
while(p) 

if(!strcmp(p->sno,no)) 
break; 
else 

temp=p; 
p=p->next; 


printf("\n学号 姓名 年龄 性别 系 班 年级 "); 
LinePrint(p); 
break; 
case 2: 
printf("\n请输入要查询的姓名:"); 
scanf("%s",name); 
printf("\n学号 姓名 年龄 性别 系 班 年级 "); 
while(p) 

if(!strcmp(p->sname,name)) 
LinePrint(p);  
p=p->next; 

break; 
case 3: 
printf("\n请输入学生所在的系:"); 
scanf("%s",departm); 
printf("\n学号 姓名 年龄 性别 系 班 年级 "); 
while(p) 

if(!strcmp(p->depart,departm)) 
LinePrint(p); 
p=p->next; 

break; 
case 4: 
printf("\n请输入学生所在的班:"); 
scanf("%s",clss); 
printf("\n请输入学生所在的年级:");  
scanf("%s",grades);  
printf("\n学号 姓名 年龄 性别 系 班 年级 "); 
while(p) 

if(!strcmp(p->classs,clss)&&!strcmp(p->grade,grades)) 
LinePrint(p); 
p=p->next; 

break; 

case 5: 
printf("\n请输入学生所在的年级:"); 
scanf("%s",grades); 
printf("\n学号 姓名 年龄 性别 系 班 年级 "); 
while(p) 

if(!strcmp(p->grade,grades)) 
LinePrint(p); 
p=p->next; 

break; 

case 6: 
print(); 
break; 

case 7: 
return; 
default: 
printf("很抱歉,暂无此查询方式!"); 
break; 





void modify()//修改学生信息 

char num[max]; 
student *p=head; 
printf("\n请输入要修改的学生的学号:"); 
scanf("%s",num); 
while(p) 

if(!strcmp(p->sno,num)) 
break; 
else 
p=p->next; 

if(p==NULL) 

printf("\n错误:没有此学生的信息!\n"); 
return; 


LinePrint(p); 

printf("\n请输入要修改的该学生的信息:"); 
printf("\n1.姓名"); 
printf("\n2.性别"); 
printf("\n3.年龄"); 
printf("\n4.所在的系"); 
printf("\n5.所在的班"); 
printf("\n6.所在的年级"); 

char name1[max],sex1[max],age1[max],depart1[max],class1[max],grade1[max]; 
int select; 
fflush(stdin); 
scanf("%d",&select); 
printf("\n请输入新的信息:"); 

switch(select) 

case 1: 
scanf("%s",name1); 
strcpy(p->sname,name1); 
break; 
case 2: 
scanf("%s",sex1); 
strcpy(p->sex,sex1); 
break; 
case 3: 
scanf("%s",age1); 
strcpy(p->age,age1); 
break; 
case 4: 
scanf("%s",depart1); 
strcpy(p->depart,depart1); 
break; 
case 5: 
scanf("%s",class1); 
strcpy(p->classs,class1); 
break; 
case 6: 
scanf("%s",grade1); 
strcpy(p->grade,grade1); 
break; 
default: 
printf("\nError!"); 
break; 


LinePrint(p); 
return; 


void del()// 删除某学生的信息 

student *p=head,*temp=head,*s; 
char num1[max]; 
printf("\n请输入要删除的学生的学号:"); 
scanf("%s",num1); 
while(p)//查找该学生所在的结点 

if(!strcmp(p->sno,num1)) 
break; 
else 

temp=p; 
p=p->next; 


}//while 
if(!p)  

printf("\n不存在此学生的信息."); 
return; 

LinePrint(p);//输出该学生的信息 
printf("\n请问真的要删除该学生的信息吗?(Y/N)"); 
char ch; 
fflush(stdin); 
scanf("%c",&ch); 
if(ch=='Y'||ch=='y') 

s=p->next; 
temp->next=s; 
free(p); 
printf("\n已经删除该学生的信息."); 

return; 


void sort() //排序模块。将学生记录按学号从小到大排列。用起泡排序算法实现 


student *ptr,*s=head,*p; 
int count=0,count1; 
while(s)//统计链表结点个数 

count++; 
s=s->next; 


for(int i=1;i<count;i++) 

ptr=head; 
p=NULL; 
count1=count-i; //用来控制每轮起泡排序的终点,即每次把学号最小的结点移到倒数第i个结点 
while(ptr&&ptr->next&&(count1--)) 

if(strcmp(ptr->sno,ptr->next->sno)>0) 

s=ptr->next; 
ptr->next=s->next; 
if(p==NULL) //ptr处于队头时 
head=s; 
else 
p->next=s; 
s->next=ptr; 
p=s; 

else 

ptr=ptr->next; 
if(p==NULL) //ptr处于队头时 
p=head; 
else 
p=p->next; 



return; 


void quit() 

char ch; 
printf("\n真的要退出?(Y/N)"); 
fflush(stdin); 
scanf("%c",&ch); 
if(ch=='Y'||ch=='y') 
exit(0); 
return; 


int main() 

int option; 

printf("\nCopyright@2005 KongXinCai All rights reserved."); 
printf("\n欢迎使用学生信息管理系统!\n"); 

//登录模块 
int icheck=0; 
while(icheck<3) 

if(LogOn()==0) 
icheck++; 
else 
break; 


if(icheck==3) 

printf("\n连续登录三次不成功,退出!"); 
exit(0); 


//系统界面 

while(1) 

printf("\n\n请选择需要的服务:"); 
printf("\n1.注册"); 
printf("\n2.查询"); 
printf("\n3.修改"); 
printf("\n4.删除"); 
printf("\n5.排序"); 
printf("\n7.求平均");
printf("\n6.退出\n"); 

scanf("%d",&option); 

switch(option) 

case 1: 
regist(); 
break; 
case 2: 
search(); 
break; 
case 3: 
modify(); 
break; 
case 4: 
del(); 
break; 
case 5: 
sort(); 
break; 
case 6: 
quit(); 
break; 




return 0; 

}

#include <iostream>
#include <fstream>
#include <string>
#include <conio.h>//用getch();
using namespace std;
/*程序中一般用i表示学生序号,j表示科目序号
*其他循环变量用k,m,n表示
*最多统计10科50人的成绩信息
*temname用于临时储存姓名
*temsub用于临时储存科目名称
*data.txt用于储存成绩; data1.txt用于储存学科名称、学时、学分; data2.txt用于储存学生信息
*/
char name[51][20] ; //姓名
int Id[51] ; //学号
int sex[51] ; //性别
int tel[51] ; //联系方式
char subject[11][20] ; //学科
int score[11][51] ; //成绩 格式为score[j][i] j i 以1为初始值
int shi[11] ; //学时
int fen[11] ; //学分
/*添加科目*/
void subadd () //添加科目
{
int j;
char subjectname[20];
cout<<"输入添加科目名称:\t";
cin>>subjectname;
for (j=1;j<=10;j++)
{
if (strcmp(subject[j],"KONG")==0)
{
strcpy(subject[j],subjectname);
break;
}
}
cout<<endl<<"输入该科目学时:\t\t";
cin>>shi[j];
cout<<endl<<"输入该科目学分:\t\t";
cin>州圆迟>fen [j];
cout<<endl<<"输入任意字符退出"<<endl;
getch();
}
/*删除科目*/
void subdel () //删除科目
{
int i,j,k;
char temsub[20];
cout<<"输入科目:"<<endl;
cin>>temsub;
for (j=1;j<=10;j++) //查找科目j
{
if ((strcmp(subject[j],temsub)!=0)&&(j==10))
{
cout<<"无此科腔谨目!"<<endl<<"输入任意字符退出"<<endl;
getch();
return;
}
if (strcmp(subject[j],temsub)==0)
break;
}
for (k=j;k<=9;k++)
{
strcpy(subject[k],subject[k+1]); //删除科目j,将科目j后的数据移动
shi[k]=shi[k+1];
fen[k]=fen[k+1];
for (i=1;i<=50;i++) //删除科目j的成绩
{
score[k][i]=score[k+1][i];
}
}
cout<<"输入任意字符退出"<<endl;
getch();
}
/*判断成绩等级*/
void dengji(int af) //判断成绩等级
{
if (af>=90) cout<<"A";
else if (af>=80) cout<<"B";
else if (af>=70) cout<<"C";
else if (af>=60) cout<<"D";
else cout<<"E";
}
/*添加学生*/
void stuadd () //添加学生
{
int i,j;
char bijiao[20]="\0";
for (i=1;i<=50;i++)
{
if (strcmp(name[i],"KONG")==0)
break;
if ((strcmp(name[i],"KONG")!=0)&&(i==50))
{
cout<<"数据已满!"<<endl<<"输入任意字符退出"<<endl;
getch();
return;
}
}
cout<<"输入学生姓名:\t\t";
cin>>name[i];
cout<<endl<<"输入学生性别(男1/女2):";
cin>>sex[i];
cout<<endl<<"输入学生学号:\t\t";
cin>>Id[i];
cout<<endl<<"输入学生联系册李方式:\t";
cin>>tel[i];
for (j=1;j<=10;j++)
{
if (strcmp(subject[j],"KONG")==0) break;
cout<<"输入"<<subject[j]<<"成绩:\t\t";
cin>>score[j][i];
cout<<endl;
}
cout<<"姓名\t\t"<<name[i]<<endl<<"性别\t\t"<<sex[i]<<endl<<"学号\t\t"<<Id[i]<<endl<<"联系方式\t"<<tel[i]<<endl;
cout<<"科目\t\t分数\t\t等级\t\t"<<endl;
for (j=1;j<=10;j++)
{
if (strcmp(subject[j],"KONG")==0) break;
cout<<subject[j]<<"\t\t"<<score[j][i]<<"\t\t";
dengji(score[j][i]);
cout<<endl;
}
cout<<"输入任意字符退出"<<endl;
getch();
}
/*删除学生*/
void studel () //删除学生
{
int i,j,k;
char temname[20];
cout<<"输入学生姓名:"<<endl;
cin>>temname;
for (i=1;i<=50;i++)
{
if ((strcmp(name[i],temname)!=0)&&(i==50))
{
cout<<"无此学生!"<<endl<<"输入任意字符退出"<<endl;
getch();
return;
}
if (strcmp(name[i],temname)==0)
break;
}
for (k=i;k<=49;k++)
{
strcpy(name[k],name[k+1]);
Id[k]=Id[k+1];
sex[k]=sex[k+1];
tel[k]=tel[k+1];

}
for (k=i;k<=49;k++)
{
for (j=1;j<=10;j++)
score[j][k]=score[j][k+1];
}
cout<<"输入任意字符退出"<<endl;
getch();
}
/*查询成绩*/
void chengji () //查询成绩
{
char temname[20];
int i,j=1,ji=0,zongfen=0; //学分积,总学分 ji为学分积,zongfen为总学分
cout<<"输入学生姓名:"<<endl;
cin>>temname;
cout<<endl;
for (i=1;i<=50;i++) //查找学生
{
if ((strcmp(name[i],temname)!=0)&&(i==50))
{
cout<<"无此学生!"<<"输入任意字符退出"<<endl;
getch();
return;
}
if (strcmp(name[i],temname)==0)
break;
}
cout<<"姓名\t\t"<<name[i]<<endl<<"性别\t\t"<<sex[i]<<endl<<"学号\t\t"<<Id[i]<<endl<<"联系方式\t"<<tel[i]<<endl;
if (strcmp(subject[j],"KONG")!=0) cout<<"科目\t\t"<<"成绩\t\t"<<"等级\t\t"<<endl;
for (j=1;j<=10;j++)
{
if (strcmp(subject[j],"KONG")==0) break;
cout<<subject[j]<<"\t\t"<<score[j][i]<<"\t\t";
dengji(score[j][i]);
cout<<endl;
}
for (j=1;j<=10;j++) //计算学分积
{
if (strcmp(subject[j],"KONG")==0) break;
ji=ji+score[j][i]*fen[j];
zongfen=zongfen+fen[j];
}
ji=ji/zongfen;
cout<<"学分积\t\t"<<ji<<endl;
cout<<"输入任意字符退出"<<endl;
getch();
}
/*成绩统计*/
void tongji () //成绩统计
{
char temsub[20],na[51][20],tempna[20];
int sc[51],tempsc;
int j,k,m;
cout<<"输入科目名称:"<<endl;
cin>>temsub;
cout<<endl;
for (j=1;j<=10;j++) //查找科目j
{
if ((strcmp(subject[j],temsub)!=0)&&(j==10))
{
cout<<"无此科目!"<<"输入任意字符退出"<<endl;
getch();
return;
}
if (strcmp(subject[j],temsub)==0)
break;
}
for (k=1;k<=50;k++) //成绩排序采用冒泡排序法
{
strcpy(na[k],name[k]);
sc[k]=score[j][k];
}
for (k=1;k<=50;k++)
{
for (m=1;m<51-k;m++)
{
if (sc[m]>sc[m+1])
{
tempsc=sc[m];strcpy(tempna,na[m]);
sc[m]=sc[m+1];strcpy(na[m],na[m+1]);
sc[m+1]=tempsc;strcpy(na[m+1],tempna);
}
}
}
cout<<"名次\t\t"<<"姓名\t\t"<<"成绩\t\t"<<"等级\t\t"<<endl;
for (k=50;k>=1;k--)
{
if (strcmp(na[k],"KONG")==0) break;
cout<<51-k<<"\t\t"<<na[k]<<"\t\t"<<sc[k]<<"\t\t";
dengji(sc[k]);
cout<<endl;
}
cout<<"输入任意字符退出"<<endl;
getch();
}
/*修改成绩*/
void xiugai() //修改成绩
{
int i,j;
char temname[20],temsub[20];
cout<<"要修改的学生姓名:\t";
cin>>temname;
cout<<endl;
for (i=1;i<=50;i++) //查找学生
{
if ((strcmp(name[i],temname)!=0)&&(i==50))
{
cout<<"无此学生!"<<endl<<"输入任意字符退出"<<endl;
getch();
return;
}
if (strcmp(name[i],temname)==0)
{
cout<<"输入科目名称:\t\t";
cin>>temsub;
cout<<endl;
for (j=1;j<=10;j++) //查找科目j
{
if ((strcmp(subject[j],temsub)!=0)&&(j==10))
{
cout<<"无此科目!"<<"输入任意字符退出"<<endl;
getch();
return;
}
if (strcmp(subject[j],temsub)==0)
{
cout<<"输入新的成绩:\t\t";
cin>>score[j][i];
cout<<endl;
break;
}
}
break;
}
}
cout<<"输入任意字符退出"<<endl;
getch();
}
/*主界面*/
void ShowMenu() //主界面
{
cout<<endl<<endl;
cout<<" 学 生 成 绩 管 理 系 统 "<<endl<<endl;
cout<<"***************************** 9.初始化程序 **************************"<<endl<<endl;
cout<<"----------------------------- 1.添加科目 --------------------------"<<endl;
cout<<"----------------------------- 2.删除科目 --------------------------"<<endl;
cout<<"----------------------------- 3.添加学生 --------------------------"<<endl;
cout<<"----------------------------- 4.删除学生 --------------------------"<<endl;
cout<<"----------------------------- 5.查询成绩 --------------------------"<<endl; //含学分积
cout<<"----------------------------- 6.各科排名 --------------------------"<<endl;
cout<<"----------------------------- 7.修改成绩 --------------------------"<<endl;
cout<<"----------------------------- 0.退出系统 --------------------------"<<endl;
cout<<"初始化同时会清空已输入的数据!!"<<endl<<"初次使用程序请初始化!!"<<endl;
cout<<"\n\t\t\n\t\t请选择:";
}
void readtxt() //读取信息
{
int i,j;
ifstream file("data.txt");
for (i=1;i<=50;i++)
{
for (j=1;j<=10;j++)
{
file>>score[j][i];
}
}
file.close();
}
void readtxt1()
{
int j;
ifstream file("data1.txt");
for (j=1;j<=10;j++)
{
file>>subject[j];
file>>shi[j];
file>>fen[j];
}
file.close();
}
void readtxt2()
{
int i;
ifstream file("data2.txt");
for (i=1;i<=50;i++)
{
file>>name[i];
file>>Id[i];
file>>sex[i];
file>>tel[i];
}
file.close();
}
/*存入成绩*/
void savetxt()
{
int i,j;
FILE *fp,*fp1,*fp2;
if ((fp=fopen("data.txt","w+"))==NULL) //存入成绩
{
cout<<"文件不能打开"<<endl;
exit(0);
}
for (i=1;i<=50;i++)
{
for (j=1;j<=10;j++)
{
fprintf(fp,"%d ",score[j][i]);
}
}
fclose(fp);

if ((fp1=fopen("data1.txt","w+"))==NULL) //存入学科名称、学时、学分
{
cout<<"文件不能打开"<<endl;
exit(0);
}
for (j=1;j<=10;j++)
{
fprintf(fp1,"%s %d %d ",subject[j],shi[j],fen[j]);
}
fclose(fp1);

if ((fp2=fopen("data2.txt","w+"))==NULL) //存入学生信息
{
cout<<"文件不能打开"<<endl;
exit(0);
}
for (i=1;i<=50;i++)
{
fprintf(fp2,"%s %d %d %d ",name[i],Id[i],sex[i],tel[i]);
}
fclose(fp2);
}
void chu() //初始化程序,将所有数据赋值"KONG"或0
{
int i,j;
for (j=0;j<=10;j++) //"KONG"用于表示空值,无数据
{
shi[j]=0;
fen[j]=0;
strcpy(subject[j],"KONG");
for (i=1;i<=50;i++)
{
score[j][i]=0;
}
}
for (i=0;i<=50;i++)
{
Id[i]=0;
sex[i]=0;
tel[i]=0;
strcpy(name[i],"KONG");
}
savetxt();
}
int main ()
{
system("color 30");//背景湖蓝色,字符黑色
int x,j,i=0;

readtxt ();
readtxt1();
readtxt2();
bool quit=false;
cout<<"\t\t -------------------------------------------------"<<endl; //欢迎界面开始
for(i=0;i<2;i++)
cout<<"\t\t|\t\t\t\t\t\t |"<<endl;
cout<<"\t\t|★★★★【 欢迎进入学生成绩管理系统 】★★★★ |"<<endl;
for(i=0;i<2;i++)
cout<<"\t\t|\t\t\t\t\t\t |"<<endl;
cout<<"\t\t -------------------------------------------------\n"<<endl; //欢迎界面结束
cout<<endl<<"\t\t按任意键开始";
getch();
while(!quit)
{
system("cls");
ShowMenu(); //显示主界面
cin>>x;
switch(x)
{
case 0:quit=true;break;
case 1:subadd();break;
case 2:subdel();break;
case 3:stuadd();break;
case 4:studel();break;
case 5:chengji();break;
case 6:tongji();break;
case 7:xiugai();break;
case 9:chu();break;
}
}
savetxt(); //程序退出前将数据存入记事本
return 0;
}