
<<"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
}
/*接下一楼*/
#include(stdio.h)
main()
{struct student
{long number
char name[20]
float score[4]
}person[10]
int i
printf("请输入10名学生的学号、姓名、及三门成绩:")
for(i=0i<10i++)
scanf("%d,%s,%d,%d,%d",&person[i]->number,person[i]->name,&person->score[0],&person->score[1],&person->score[2])
for(i=0,i<10i++)
person->score[3]=(person->score[0]+person->score[1]+person->score[2])/3
printf("10名同学的情况如下:\n")
for(i=0i<10i++)
printf("学号:%d 姓名:%s 成绩:%d %d %d 平均成绩:%d\n",person[i]->number,person[i]->name[20],person->score[0],person->score[1],person->score[2],person->score[3])
}
拓展资料
C语言是一门通用计算机编程语言,应用广泛。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。
尽管C语言提供了许多低级处理的功能,但仍然保持着良好跨平台的特性,以一个标准规格写出的C语言程序可在许多电脑平台上进行编译,甚至包含一些嵌入式处理器(单片机或称MCU)以及超级电脑等作业平台。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)