#include<stdlib.h>
#include<string.h>struct record
{
char xuehao[10]//学号
char name[20]//姓名
char sex[3]//性别
int ke1//数学
int ke2 //语文
int ke3//英语
int pin
}stu[50]
int k=1,n,mvoid readfile()
void seek()
void insert()
void del()
void save()
void menu()
void seek()
{int i,j,item,flag<br>char s1[20]<br>printf("------------------\n")<br>printf("1.按学号查询\n")<br>printf("2.退出本菜单\n")<br>printf("------------------\n")<br>while(1)<br>{ printf("请选择子菜单编号:")<br>scanf("%d",&item)<br>flag=0<br>switch(item)<br>{<br>case 1:<br>printf("请输入要查询的学生的学号:\n")<br>scanf("%s",s1)<br>for(i=0i<ni++)<br>if(strcmp(stu[i].xuehao,s1)==0)<br>{ flag=1<br>printf("该学生学号,姓名,性别,数学,语文,英语 分别为:\n")<br>printf("%s%s%s %d%d%d",stu[i].xuehao,stu[i].name,<br>stu[i].sex,stu[i].ke1,stu[i].ke2,stu[i].ke3)<br>}
if(flag==0)
printf("该学号不存在!\n")break
case 2:return
default:printf("请在1-2之间选择\n")
}
}
}
void insert()
{ int i=n,j,flag
printf("请输入待增加的学生数:\n")
scanf("%d",&m)
do
{ flag=1
while(flag)
{ flag=0
printf("请输入第 %d 个学生的学号:\n",i+1)
scanf("%s",stu[i].xuehao)
for(j=0j<ij++)
if(strcmp(stu[i].xuehao,stu[j].xuehao)==0)
{ printf("已有该学号,请检查后重新录入!\n")
flag=1
break
}
}
printf("请输入第 %d 个学生的姓名:",i+1)
scanf("%s",stu[i].name)
printf("\n请输入第 %d 个学生的性别:",i+1)
scanf("%s",stu[i].sex)
printf("\n请输入第 %d 个学生的数学成绩:",i+1)
scanf("%d",&stu[i].ke1)
printf("\n请输入第 %d 个学生的语文成绩:",i+1)
scanf("%d",&stu[i].ke2)
printf("\n请输入第 %d 个学生的英语成绩:",i+1)
scanf("%d",&stu[i].ke3)if(flag==0)
{ i=i
i++
}
}while(i<n+m)
n+=m
printf("录入完毕!\n\n")
}void del()
{ int i,j,flag=0
char s1[20]
printf("请输入要删除学生的学号:\n")
scanf("%s",s1)
for(i=0i<ni++)
if(strcmp(stu[i].xuehao,s1)==0)
{ flag=1
for(j=ij<n-1j++)
stu[j]=stu[j+1]
}
if(flag==0)
printf("该学号不存在!\n")
if(flag==1)
{ printf("删除成功,显示结果请选择菜单6\n")
n--
}
}
void readfile()
{
char buf[80],*p="student.dat"
FILE *fp
int i=0
if ((fp=fopen("student.dat","r"))==NULL)
{ printf("Open file %s error! Strike any key to exit!",p)
system("pause")
exit(0)
}
while(fscanf(fp,"%s%s%s%d%d%d",stu[i].xuehao,stu[i].name,
stu[i].sex,&stu[i].ke1,&stu[i].ke2,&stu[i].ke3)==6)
{ i++
i=i
}
fclose(fp)
n=i
printf("录入完毕!\n")
}void save()
{ int i,j,k,flag=0
FILE *fp
fp=fopen("student.dat","w")
for(i=0i<mi++)
{
fprintf(fp,"%s%s%d%d%d",stu[i].xuehao,stu[i].name,stu[i].sex,&stu[i].ke1,
&stu[i].ke2,&stu[i].ke3)
fclose(fp)
printf("已储存")
}
}
void paixu()
{
int i,j,k,t
for(i=0i<mi++)
{
stu[i].pin=(stu[i].ke1+stu[i].ke2+stu[i].ke3)/3
}
for(i=0i<=m-2i++)
{
k=i
for(j=i+1j<=m-1j++)
if(stu[j].pin<stu[k].pin)
k=j
if(k!=i)
{
t=stu[k].pin
stu[k].pin=stu[i].pin
stu[i].pin=t
}
}
for(i=0i<mi++)
{printf("第 %d 个学生的姓名%s:",i+1,stu[i].name)<br> printf("\n第 %d 个学生的性别:%s",i+1,stu[i].sex)<br> printf("\n第 %d 个学生的数学成绩:%d",i+1,stu[i].ke1)<br> printf("\n第 %d 个学生的语文成绩:%d",i+1,stu[i].ke2)<br> printf("\n第 %d 个学生的英语成绩:%d",i+1,stu[i].ke3)<br> printf("\n第 %d 个学生的平均成绩:%d",i+1,stu[i].pin)<br>}
}
void menu()
{ int nub
printf(" \n\n学生成绩管理系统\n\n")
printf("*****系统功能菜单*****\n")
printf("----------------------\n")
printf("1.输入学生信息\n")
printf("2.查询学生信息\n")
printf("3.按学号删除信息\n")
printf("4.读入学生信息\n")
printf("5.保存信息(要把修改保存到文件,退出程序前必须执行本项)\n")
printf("6.查询学生平均成绩信息\n")
printf("0.退出系统\n")
printf("----------------------\n")
printf("请选择菜单编号:")
scanf("%d",&nub)
switch(nub)
{
case 1:insert()break
case 2:seek()break
case 3:del()break
case 4:readfile()break
case 5:save()break
case 6:paixu()break
case 0:k=0break
default:printf("请在0-6之间选择\n")
}}
void main()
{
while(k)
menu()
}
//平均数是排序后,输出的,如果你不想直接输入,那就不要对每个学生进行选择排序了
<<"1.输入/添加学生资料"<<endl<<"
2.输出学生资料"<<endl<<"
3.查找"<<endl<<"
4.删除"<<endl<<"
5.总分排序"<<endl<<"
6.退出"<<endl<<endl<<"
请选择你要的服务(1-6)"<<endlcin>>choseif(chose=='6'){break}switch(chose){case'1'://
输入学生信息{do{cout<<"
请输入学生姓名:"<<endlch1=newchar[]ch2=newchar[]cin>>ch1cout<<"
请输入学号:"<<endlcin>>numwhile(st.check_num(num)){cout<<"
学号重复,请重新输入"<<endlcin>>num}cout<<"
请输入地址:"<<endlcin>>ch2cout<<"
请输入高数成绩:"<<endlcin>>xcout<<"
请输入英语成绩:"<<endlcin>>ycout<<"
请输入计算机成绩:"<<endlcin>>zst.input(ch1,num,ch2,x,y,z)printf("\n
是否继续输入学生信息?(\"y\"继续)")scanf("%s",flag)}while(strcmp(flag,"y")==0)}breakcase'2'://
输出学生资料{temp=countcount=1cout<<"
序号\t姓名\t学号\t\t地址\t\t\t高数\t英语\t计算机"<<endlwhile(count<=temp){st.show()count++}count--getch()}breakcase'3':{cout<<"
请输入你要查找学生的学号"<<endlcin>>findst.find(find)}breakcase'4':{cout<<"
请输入你要删除的学生学号"<<endlcin>>delst.del(del)}breakcase'5':{st.taxis()}break
default:{cout<<"输入错误!!!,请重新输入"<<endlgetch()}}}cout<<"感谢你的使用!\n"<<endlgetch()
}
#include<stdio.h>
#include<windows.h>
#include<string.h>
structworker
{
intnum
charname[20]
charzhicheng[10]
intwages
intreward
longbirth
intsalary
}work[500],work1/*定义结构体*/
voidmenu()//声明菜单函数
voidtype_in()//声明录入函数
voidbaocun(int)//声明保存函数
voidscan()//声明浏览函数
voiddel()//声明删除函数
voidsearch()//声明查询函数
voidsearch_zhicheng()//声明按职称查询函数
voidsearch_name()//声明按姓名查找函数
voidchange()//声明修改函数
voidorder()//声明排序函数
voidadd()//声明添加函数
voidorder_wages()
voidorder_name()
voidmenu()/*菜单函数*/
{
printf("\n")
printf("welcometo\n")
printf("职工信息管理系统")
printf("******************************************************************************\n")
printf("1.录入职工信息\n")
printf("2.浏览职工信息\n")
printf("3.查询职工信息\n")
printf("4.删除职工信息\n")
printf("5.修改职工信息\n")
printf("6.职工信息排序\n")
printf("7.添加职工信息\n")
printf("8.退出\n")
printf("*******************************************************************************\n")
printf("\n")
}
/********************************************************************************************/
voidmain()
{
intn,f
while(1)
{
do
{
menu()/*调用菜单函数*/
printf("请输入你需要 *** 作的序号(1—8):\n")
scanf("%d",&n)
if(n>=1&&n<=8)
{
f=1
break
}
else
{
f=0
printf("您输入有误,请重新选择!")
}
}while(f==0)
switch(n)
{
case1:printf("录入职工信息\n")printf("\n")type_in()break
case2:printf("浏览职工信息\n")printf("\n")system("cls")scan()break
case3:printf("查询职工信息\n")printf("\n")system("cls")search()break
case4:printf("删除职工信息\n")printf("\n")system("cls")del()break
case5:printf("修改职工信息\n")printf("\n")system("cls")change()break
case6:printf("职工信息排序\n")printf("\n")system("cls")order()break
case7:printf("添加职工信息\n")printf("\n")system("sls")add()break
case8:gotoloop/*用goto语句跳至跳至指定的行*/
default:break
}
}
loop://行标
system("cls")
printf("\n\n\n\n\n\n-----
/*接上一楼*/struct
Student
*create()
/*create函数定义,此函数实现创建单向动态链表*/
{
struct
Student
*head=NULL,*p1,*p2
/*head,链表的头指针;*p1,*p2,中间指针变量*/
puts("\n现在请输入学院名:")
scanf("%s",college)
puts("\n年级:")
scanf("%s",grade)
puts("\n专业和班级:")
scanf("%s",classname)
puts("\n下面请按提示依次输入数据:\n(如果要结束输入,请输入学号0)")
p1=p2=(struct
Student
*)malloc(LEN)
puts("输入第一个学生的学号:")
scanf("%ld",&p1->num)
puts("输入此学生成绩:\n英语:")
scanf("%f",&p1->score.english)
puts("数学:")
scanf("%f",&p1->score.math)
puts("计算机:")
scanf("%f",&p1->score.computer)
total_and_aver(p1)/*计算总分和平均分*/
p1->grade=mark_grade(p1)
for(p1->num!=0)
{
len++
if(len==1)
head=p1
else
p2->next=p1
p2=p1
p1=(struct
Student
*)malloc(LEN)
puts("输入下一个学生的学号:")
scanf("%ld",&p1->num)
puts("输入此学生成绩:\n英语:")
scanf("%f",&p1->score.english)
puts("数学:")
scanf("%f",&p1->score.math)
puts("计算机:")
scanf("%f",&p1->score.computer)
total_and_aver(p1)/*计算总分和平均分*/
p1->grade=mark_grade(p1)
}
p2->next=NULL
return
(head)
}
struct
Student
*del(struct
Student
*head,long
del_num)
/*del函数定义,此函数实现从现有链表中删除一个结点*/
{
struct
Student
*p1,*p2
if(head==NULL)
puts("空表,没有任何数据记录。\n")
else
{
for(p1=head!(del_num==p1->num||p1->next==NULL)p2=p1,p1=p1->next)
if(del_num==p1->num)
{
if(p1==head)head=p1->next
else
p2->next=p1->next
printf("学号为%ld学生的数据删除成功。\n",del_num)
--len
}
else
printf("未找到学号为%ld学生的记录。\n",del_num)
}
return
(head)
}
struct
Student
*insert(struct
Student
*head,struct
Student
*new_student)
/*insert函数定义,此函数实现向现有链表中插入一个结点或覆盖相同学号的数据*/
{
struct
Student
*p0=new_student,*p1=head,*p2
char
control
if(head==NULL)
{
head=p0
p0->next=NULL
puts("数据插入成功。\n")
}
else
{
for(((*p0).num>(*p1).num)&&(p1->next!=NULL)p2=p1,p1=p1->next)
if((*p0).num==(*p1).num)
{
printf("已经存在一个学号为%ld的学生的数据,要覆盖原有数据吗?\n输入
Y
=覆盖原有数据\n输入其它=保留原有数据\n",p0->num)
FFLUSH
scanf("%c",&control)
FFLUSH
switch
(control)
{
case
'Y':
case
'y':if(p1==head){head=p0p0->next=p1->next}
else
{p2->next=p0p0->next=p1->next}
puts("数据已经更新\n")break
default:break
}
len--
}
else
if((*p0).num<(*p1).num)
{
if(p1==head)head=p0
else
p2->next=p0
p0->next=p1
puts("数据插入成功。\n")
}
else
{
p1->next=p0
p0->next=NULL
puts("数据插入成功。\n")
}
}
++len
return
(head)
}
struct
Student
*sort(struct
Student
*head)
/*sort函数定义,此函数实现对链表中的数据按照平均分高低排序*/
{
struct
Student
*p1,*p2
for(p1=headp1->next!=NULLp1=p1->next)
for(p2=p1->nextp2!=NULLp2=p2->next)
{
if(p1->score.average<p2->score.average)
{
SWAP(p1->num,p2->num)
SWAP(p1->grade,p2->grade)
SWAP(p1->score.english,p2->score.english)
SWAP(p1->score.math,p2->score.math)
SWAP(p1->score.computer,p2->score.computer)
SWAP(p1->score.total,p2->score.total)
SWAP(p1->score.average,p2->score.average)
}
}
return
head
}
/*接下一楼*/
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)