[精品]职工管理系统_第1页
[精品]职工管理系统_第2页
[精品]职工管理系统_第3页
[精品]职工管理系统_第4页
[精品]职工管理系统_第5页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、#inckidc "stdlib.h" /*标准库函数*/#include "ctype.h" /*字符操作函数*/#include "string.h"typedef struct /*定义数据结构*/char name20; /*姓名 */char num10; /*工号 */char agelloj; /* 年龄 */char money10;/*工资 */address;/*以下是函数原型*/int enter(address t); /*建立职工信息*/void list(address t,int n); /*输出职工信息

2、*/void search(address t,int n); /*按工号查找职工信息*/int delete(address t,int n); /*删除一个职工信息*/int add(address t,int n); /*增加一个职工信息,并显示修改后的效果*/ void sort(address t,int n); /*按工资降序排序*/int find(address t,int n,char *s);void main()address adr4;/*定义结构体数组*/int length;int n;printfc' 1.建立职工信息5”);printf(n 2.输出职工

3、信息n”);printfc 3.以工号查找职工信息n”);printf(m 4.删除一个职工信息n”);printf(m 5.增加一个职工信息并显示修改后的效果n“);printfc 6.按工资降序排序n”);printf(n“);printf(m 7.退出n“);f irtwrtwrtw rtwrtwrrw riw riwriw »twriw rjwscanf(" %d" ,&n) ;/* 录入选择*/switch(n) /*选择n作开关语句的条件*/ case l:enter(adr);break; /*建立职工信息*/ case 2:list(adr

4、,2);break; /*输出职工信息*/ case 3:search(adr,2);break; /*查找*/ case 4:lcngth=dclctc(adr,2);brcak; /*删除*/ case 5:length=add(adr,2); break; /*增加 */ case 6:sort(adr,2);break; /*按工资排序*/ case 7:exit(0); /*如n为7则程序结束*/*建立职工信息,形参为结构体数组,函数值返回类烈为整型表示记录长度*/int enter(address tj)int i;char *s;printf(m请输入职工信息n");

5、/*提示输入记录*/ printf("name num age moneyn");printf(m-nh);for(i=0;i<2;i+)scanf("%s%s%s%sn,,tij.num,ti.age,ti.money); /* 输入记录 */printf(mnh);/*输出职工信息*/void list(address t,int n)int i;printf(uname num age moneynm);printf(m-nh);for(i=0;i<2;i+)printf(m姓名:%s 工号:%s 年龄:%s 工资:%sii&quo

6、t;,,ti.num,ti.age,ti.money);/*查找职工信息*/void search(address n)char s20j; /*保存待查找工号字符串*/ inti; /*保存查找到结点的序号*/ printf(m请输入需要查找的职工的工号n“); scanf(”s”,s); /*输入待查找工号*/ i=find(t,2,s);/*调用find函数,得到一个整数*/八查找函数,参数为记录数组和记录条数以及姓名s*/ int find(address t,int n,char *s)int i;for(i=0;i<2;i+)/*从第一条记录开始,肓到最麻一条*

7、/ if(strcmp(s,ti.num)=o) /*记录中的职工工号和待比较的工号是否相等*/reuirni;/*相等,则返回该记录的下标号,程序提前结结束*/return i; /*返冋 i 值*/*删除两数,参数为记录数组和记录条数*/int delete(address tj,int n)char s20;/*要删除记录的姓名*/int ch=o;int i,j;printf(”谙输入需要删除的职工姓名n“);/*捉示信息引scanf(”s”,s);/* 输入姓名*/i=find(t,n,s); /*调用 find 函数*/if(i>n-l)/*如果i>n-l超过了数组的长

8、度*/printf(”对不起未找到对应信息,删除不成功n“); /*显示没找到要删除的记录*/else printf(n姓名:s 工号:s 年龄:s 工资:%sn",,ti.num,ti.age,ti.money); /* 显示该条记录信息*/printf(”确定删除该职工的信息(1/o)n“);严确认是否要删除*/scanf(”d“,&ch); /*输入一个整数 0 或 1*/if(ch=l)/*如果确认删除整数为1*/for(j=i+l;j<n;j+) /*删除该记录,实际后续记录前移*/strcpy(t j -1 . name,t j . name)

9、; /*将后一条记录的姓名拷贝到前一条*/ strcpy(tj-l.age,tj.age); /*将后一条记录的年龄拷贝到前一条*/ strcpy (t j -1 . money, t j . money); /*将后一条记录的工资拷贝到前一条*/ void sort(address tf,int n)int i,j,flag;address temp; /*临时变量做交换数据用*/for(i=0;iv2;i+)flag=0; /*设标志判断是否发生过交换旬for(j=0;j<n-l;j+)if(strcmp(tjj.money,t|j+l .money)>0) /* 比较大小 *

10、/ flag=l;strcpy(,); /*交换记录*/strcpy(temp.num,tjj.num);strcpy(temp.age,t|jj.age);strcpy(temp.money,tjl.money);strcpy(tj.namc4j+1 .namc);strcpy(tj.num,tj+l.num);strcpy(tj.age,tj+l.age);strcpy(tlj. money,tj+lj money);strcpy(tfj+11.name,);strcpy(tj+1 .num,temp.num);strcpy(tj+1.a

11、ge,temp-age);strcpy(tj+l j.money,temp.money);if(flag=o)brcak;/*如果标志为0,说明没冇发生过交换循环结束*/printf(”排序成功! !n”); /*显示排序成功*/*插入职工信息函数,参数为结构体数纟r和记录数*/int add(address t,int n)/*插入函数,参数为结构体数组和记录数*/address temp; /*新插入记录信息*/ int i,j;char s20; /*确定插入在哪个记录之前*/ printfc*请输入信息);printf("name num age moneynh);print

12、fc*n“);scanf(m%s%s%s%su,,temp.num,temp.age,temp.money); /*输入插入信息*/printf(m-nh);printfc请输入插入哪位职工姓名z前n“); scanf(”s”,s); /*输入插入位置的姓名*/ i=find(t,2,s); /*调用find,确定插入位置*/ for(j=2-l;j>=i;j-) /*从最后一个结点开始向后移动一条*/ strcpy(tj+1.name,); /*当前记录的姓名拷贝到后一条*/ strcpy(tj+l.num,tj.num); /*当前记录的工号拷贝到后一条*/ strcpy(t j+1 .age,tfj .age); /*当前记录的年龄拷贝到后一条*/ strcpy(tj+l.money,t|j.money);strcpy(,); /*将新插入记录的姓名拷贝到笫i个位置*/ strcpy(tij.num,temp.num); /*将新插入记录的工号拷贝到笫i个位置*/ strcpy(tli.age,tem

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论