c员工管理系统源代码(c语言职工管理系统源代码)
admin 发布:2022-12-19 18:15 193
本篇文章给大家谈谈c员工管理系统源代码,以及c语言职工管理系统源代码对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
c++职工管理信息系统
附1、:使用说明
输入1注册信息:注册职工信息时提示注册员工的个数,且系统会自动给出职工编号,然后输入职工姓名、性别、年龄、学历、工资、地址、联系电话。
输入2浏览信息:操作后可以浏览该公司所有职工的信息。
输入3查询信息:可以根据不同的信息查询公司职工的信息。如按照职工的编号、职工的学历、职工的联系电话。知道职工的其中一个信息就可以查到他的其他信息。实现了掌握少量的信息就可以找到相关的信息。
输入4删除信息:介入这一界面时,先显示全部职工的信息,再输入需要删除职工的名字。操作后可显示删除后的全部职工的信息。
输入5添加信息:进入这一界面后,先显示原来的职工的信息,再提示添加信息的人数,然后输入新的职工的信息。操作完后可自动显示添加完后的全部职工的信息。
输入6修改信息:介入界面后,显示全部职工的信息,再提示输入需要修改的职工的姓名,输入后显示该职工原来的信息且提示是否修改:输入1时修改,输入0时不修改。需要修改时,提示需要修改的选项的序号,然后进行修改。修改后系统自动显示修改后的职工的信息。
附件:职工信息管理系统代码
file.c
此文件主要包含涉及文件读写功能的函数。
/************************************************************/
/* File: file.c */
/************************************************************/
#include stdio.h
#include windows.h
#include time.h
#include string.h
#define N 100 /*宏定义*/
struct employee
{ int num; /*职工编号*/
char name[10]; /*职工姓名*/
char sex[4]; /*职工性别*/
char bir[16]; /*职工出生年月*/
char xueli[30]; /*职工学历*/
int wage; /*职工工资*/
char addr[30]; /*职工地址*/
char tel[20]; *职工电话*/
}em[100]; /*定义一个结构体*/
void menu() /*菜单函数*/
{
printf(" ☆☆☆信息管理与信息系统☆☆☆\n");
printf("\n");
printf(" B0902 李颖\n");
printf("\n");
printf(" ******************职工信息管理****************\n");
printf(" 1.录入职工信息");
printf(" 2.浏览职工信息\n");
printf(" 3.查询职工信息");
printf(" 4.删除职工信息\n");
printf(" 5.添加职工信息");
printf(" 6.修改职工信息\n");
printf(" 7.退出管理系统\n");
printf(" **********************************************\n");
printf("\n");
printf("\n");
}
void main()
{
menu(); /*调用菜单函数*/
int n,flag;
char a;
do
{ printf("请选择你需要操作的步骤(1--7):\n");
scanf("%d",n);
if(n=1n=7)
{
flag=1;
break;
}
else
{
flag=0;
printf("您输入有误,请重新选择!");
}
}
while(flag==0);
while(flag==1)
{ switch(n)
{
case 1:printf(" ◆◆◆输入职工信息◆◆◆\n");printf("\n");input();break;
case 2:printf(" ◆◆◆浏览职工信息◆◆◆\n");printf("\n");display();break;
case 3:printf(" ◆◆◆查询职工信息◆◆◆\n");printf("\n");search();break;
case 4:printf(" ◆◆◆删除职工信息◆◆◆\n");printf("\n");del();break;
case 5:printf(" ◆◆◆添加职工信息◆◆◆\n");printf("\n");add();break;
case 6:printf(" ◆◆◆修改职工信息◆◆◆\n");printf("\n");modify();break;
case 7:exit(0);break;
default :break;
}
getchar();
printf("\n");
printf("是否继续进行(y or n):\n");
scanf("%c",a);
if(a=='y')
{
flag=1;
system("cls"); /*清屏*/
menu(); /*调用菜单函数*/
printf("请再次选择你需要操作的步骤(1--6):\n");
scanf("%d",n);
printf("\n");
}
else
exit(0);
}
}
void input() /*录入函数*/
{
int i,m;
printf("请输入需要创建信息的职工人数(1--100):\n");
scanf("%d",m);
for (i=0;im;i++)
{
printf("职工号: ");
srand((int)time(0));
em[i].num=rand()%10000+20000000;
if(em[i].num!=em[i-1].num)
printf("%8d ",em[i].num);
printf("\n");
printf("请输入姓名: ");
scanf("%s",em[i].name);
getchar();
printf("请输入性别: ");
scanf("%s",em[i].sex);
printf("请输入出生年月: ");
scanf("%s",em[i].bir);
printf("请输入学历: ");
scanf("%s",em[i].xueli);
printf("请输入工资: ");
scanf("%d",em[i].wage);
printf("请输入住址: ");
scanf("%s",em[i].addr);
printf("请输入电话: ");
scanf("%s",em[i].tel);
printf("\n");
}
printf("\n创建完毕!\n");
save(m);
}
void save(int m) /*保存文件函数*/
{
int i;
FILE*fp;
if ((fp=fopen("employee_list","wb"))==NULL) /*创建文件并判断是否能打开*/
{
printf ("cannot open file\n");
exit(0);
}
for (i=0;im;i++) /*将内存中职工的信息输出到磁盘文件中去*/
if (fwrite(em[i],sizeof(struct employee),1,fp)!=1)
printf("file write error\n");
fclose(fp);
}
int load() /*导入函数*/
{
FILE*fp;
int i=0;
if((fp=fopen("employee_list","rb"))==NULL)
{
printf ("cannot open file\n");
exit(0);
}
else
{
do
{
fread(em[i],sizeof(struct employee),1,fp);
i++;
}
while(feof(fp)==0);
}
fclose(fp);
return(i-1);
}
void display() /*浏览函数*/
{
int i;
int m=load();
printf("\n 职工号\t姓名\t性别\t出生年月\t学历\t工资\t住址\t电话 \n");
for(i=0;im;i++) /*m为输入部分的职工人数*/
printf("\n %6d\t%s\t%4s\t%s\t%s\t%d\t%s\t%s\n",em[i].num,em[i].name,em[i].sex,em[i].bir,em[i].xueli,em[i].wage,em[i].addr,em[i].tel);
}
void del() /*删除函数*/
{ int m=load();
int i,j,n,t,flag;
char name[20];
printf("\n 原来的职工信息:\n");
display(); /* 调用浏览函数*/
printf("\n");
printf("请输入要删除的职工的姓名:\n");
scanf("%s",name);
for(flag=1,i=0;flagim;i++)
{
if(strcmp(em[i].name,name)==0)
{
printf("\n已找到此人,原始记录为:\n");
printf("\n职工号\t姓名\t性别\t出生年月\t学历\t工资\t住址\t电话 \n");
printf("\n%d\t%s\t%s\t%s\t%s\t%d\t%s\t%s\n",em[i].num,em[i].name,em[i].sex,em[i].bir,em[i].xueli,em[i].wage,em[i].addr,em[i].tel);
printf("\n确实要删除此人信息请按1,不删除请按0\n");
scanf("%d",n);
if(n==1) /*如果删除,则其他的信息都往上移一行*/
{
for(j=i;jm-1;j++)
{
strcpy(em[j].name,em[j+1].name);
em[j].num=em[j+1].num;
strcpy(em[j].sex,em[j+1].sex);
strcpy(em[j].bir,em[j+1].bir);
strcpy(em[j].xueli,em[j+1].xueli);
em[j].wage=em[j+1].wage;
strcpy(em[j].addr,em[j+1].addr);
strcpy(em[j].tel,em[j+1].tel);
}
flag=0;
}
}
}
if(!flag)
m=m-1;
else
printf("\n对不起,查无此人!\n");
printf("\n 浏览删除后的所有职工信息:\n");
save(m); /*调用保存函数*/
display(); /*调用浏览函数*/
printf("\n继续删除请按1,不再删除请按0\n");
scanf("%d",t);
switch(t)
{
case 1:del();break;
case 0:break;
default :break;
}
}
void add() /*添加函数*/
{
FILE*fp;
int n;
int count=0;
int i;
int m=load();
printf("\n 原来的职工信息:\n");
display(); /* 调用浏览函数*/
printf("\n");
fp=fopen("emploee_list","a");
printf("请输入想增加的职工数:\n");
scanf("%d",n);
for (i=m;i(m+n);i++)
{
printf("\n 请输入新增加职工的信息:\n");
printf("请输入职工号: ");
srand((int)time(0));
em[i].num=rand()%10000+20000000;
if(em[i].num!=em[i-1].num)
printf("%8d ",em[i].num);
printf("\n");
printf("请输入姓名: ");
scanf("%s",em[i].name);
getchar();
printf("请输入性别: ");
scanf("%s",em[i].sex);
printf("请输入出生年月: ");
scanf("%s",em[i].bir);
printf("请输入学历: ");
scanf("%s",em[i].xueli);
printf("请输入工资: ");
scanf("%d",em[i].wage);
printf("请输入住址: ");
scanf("%s",em[i].addr);
printf("请输入电话: ");
scanf("%s",em[i].tel);
printf("\n");
count=count+1;
printf("已增加的人数:\n");
printf("%d\n",count);
}
printf("\n添加完毕!\n");
m=m+count;
printf("\n浏览增加后的所有职工信息:\n");
printf("\n");
save(m);
display();
fclose(fp);
}
void search() /*查询函数*/
{
int t,flag;
do
{
printf("\n按职工号查询请按1 ; 按学历查询请按2 ; 按电话号码查询请按3,进入主函数按4\n");
scanf("%d",t);
if(t=1t=4)
{
flag=1;
break;
}
else
{
flag=0;
printf("您输入有误,请重新选择!");
}
}
while(flag==0);
while(flag==1)
{
switch(t)
{
case 1:printf("按职工号查询\n");search_num();break;
case 2:printf("按学历查询\n");search_xueli();break;
case 3:printf("按电话号码查询\n");search_tel();break;
case 4:main();break;
default:break;
}
}
}
void search_num()
{
int num;
int i,t;
int m=load();
printf("请输入要查找的职工号(20001111---20009999):\n");
scanf("%d",num);
for(i=0;im;i++)
if(num==em[i].num)
{
printf("\n已找到此人,其记录为:\n");
printf("\n职工号\t姓名\t性别\t出生年月\t学历\t工资\t住址\t电话 \n");
printf("\n%d\t%s\t%s\t%s\t%s\t%d\t%s\t%s\n",em[i].num,em[i].name,em[i].sex,em[i].bir,em[i].xueli,em[i].wage,em[i].addr,em[i].tel);
break;
}
if(i==m)
printf("\n对不起,查无此人\n");
printf("\n");
printf("返回查询函数请按1,继续查询职工号请按2\n");
scanf("%d",t);
switch(t)
{
case 1:search();break;
case 2: break;
default:break;
}
}
void search_xueli()
{
char xueli[30];
int i,t;
int m=load();
printf("请输入要查找的学历:\n");
scanf("%s",xueli);
for(i=0;im;i++)
if(strcmp(em[i].xueli,xueli)==0)
{
printf("\n已找到,其记录为:\n");
printf("\n职工号\t姓名\t性别\t出生年月\t学历\t工资\t住址\t电话 \n");
printf("\n%d\t%s\t%s\t%s\t%s\t%d\t%s\t%s\n",em[i].num,em[i].name,em[i].sex,em[i].bir,em[i].xueli,em[i].wage,em[i].addr,em[i].tel);
}
if(i==m)
printf("\n对不起,查无此人\n");
printf("\n");
printf("返回查询函数请按1,继续查询学历请按2\n");
scanf("%d",t);
switch(t)
{
case 1:search();break;
case 2:break;
default :break;
}
}
void search_tel()
{
char tel[20];
int i, t;
int m=load();
printf("请输入要查找的电话号码:\n");
scanf("%ld",tel);
for(i=0;im;i++)
if(strcmp(em[i].tel,tel)==0)
{
printf("\n已找到此人,其记录为:\n");
printf("\n职工号\t姓名\t性别\t出生年月\t学历\t工资\t住址\t电话 \n");
printf("\n%d\t%s\t%s\t%s\t%s\t%d\t%s\t%s\n",em[i].num,em[i].name,em[i].sex,em[i].bir,em[i].xueli,em[i].wage,em[i].addr,em[i].tel);
break;
}
if(i==m)
printf("\n对不起,查无此人\n");
printf("\n");
printf("返回查询函数请按1,继续查询电话号码请按2\n");
scanf("%d",t);
switch(t)
{
case 1:search();break;
case 2:break;
default :break;
}
}
void modify() /*修改函数*/
{
int num;
char name[10];
char sex[4];
char bir[20];
char xueli[30];
int wage;
char addr[30];
char tel[20];
int b,c,i,n,t,flag;
int m=load(); /*导入文件内的信息*/
printf("\n 原来的职工信息:\n");
display(); /* 调用浏览函数*/
printf("\n");
printf("请输入要修改的职工的姓名:\n");
scanf("%s",name);
for(flag=1,i=0;flagim;i++)
{
if(strcmp(em[i].name,name)==0)
{
printf("\n已找到此人,原始记录为:\n");
printf("\n职工号\t姓名\t性别\t出生年月\t学历\t工资\t住址\t电话 \n");
printf("\n%d\t%s\t%s\t%s\t%s\t%d\t%s\t%s\n",em[i].num,em[i].name,em[i].sex,em[i].bir,em[i].xueli,em[i].wage,em[i].addr,em[i].tel);
printf("\n确实要修改此人信息请按1 ; 不修改请按0\n");
scanf("%d",n);
if(n==1)
{
printf("\n需要进行修改的选项\n 1.职工号 2.姓名 3.性别 4.出生年月 5.学历 6.工资 7.住址 8.电话\n");
printf("请输入你想修改的那一项序号:\n");
scanf("%d",c);
if(c8||c1)
printf("\n选择错误,请重新选择!\n");
}
flag=0;
}
}
if(flag==1)
printf("\n对不起,查无此人!\n");
do
{
switch(c) /*因为当找到第i个职工时,for语句后i自加了1,所以下面的应该把改后的信息赋值给第i-1个人*/
{
case 1:printf("职工号改为: ");
scanf("%d",num);
em[i-1].num=num;
break;
case 2:printf("姓名改为: ");
scanf("%s",name);
strcpy(em[i-1].name,name);
break;
case 3:printf("性别改为: ");
scanf("%s",sex);
strcpy(em[i-1].sex,sex);
break;
case 4:printf("出生年月改为: ");
scanf("%s",bir);
strcpy(em[i-1].bir,bir);
break;
case 5:printf("学历改为: ");
scanf("%s",xueli);
strcpy(em[i-1].xueli,xueli);
break;
case 6:printf("工资改为: ");
scanf("%d",wage);
break;
case 7:printf("住址改为: ");
scanf("%s",addr);
strcpy(em[i-1].addr,addr);
break;
case 8:printf("电话改为: ");
scanf("%s",tel);
strcpy(em[i-1].tel,tel);
break;
}
printf("\n");
printf("\n是否确定所修改的信息?\n 是 请按1 ; 不,重新修改 请按2: \n");
scanf("%d",b);
}
while(b==2);
printf("\n浏览修改后的所有职工信息:\n");
printf("\n");
save(m);
display();
printf("\n继续修改请按1,不再修改请按0\n");
scanf("%d",t);
switch(t)
{
case 1:modify();break;
case 0:break;
default :break;
}
}
c语言课程设计—教师工作量管理系统源代码
#includestdio.h //标准输入、输出头文件
#includestring.h //包含字符串函数处理头文件
#includestdlib.h //包含动态存储与释放函数头文件
#includeiostream // system
#define TEALEN sizeof(teanode) //教师信息结构体长度
#define LEN sizeof(Lnode) //链表节点长度
#define MAX 10
int SAME[MAX];
typedef struct teanode
{
char name[10]; //教师姓名
int lesson; //授课工作量
int exper; //实验工作量
int cdesign; //课程设计工作量
int gdesign; //毕业设计工作量
int total; //总工作量
int pos; //排序位置
}teanode,*linknode;//教师信息结构体
typedef struct Lnode
{
char no[20]; //教师编号
linknode info; //节点信息详细指针指向教师信息结构体
struct Lnode *prior,*next; //双向链表指针域
}Lnode,*linklist;//链表节点
void newLnode();
void initlist();
void prin();
void initlist(linklist *T)
{
*T=(linklist)malloc(LEN);
(*T)-info=(linknode)malloc(TEALEN);//为头结点申请空间
(*T)-prior=*T;//设置头结点的前驱指针
(*T)-next=*T;//设置头结点的后继指针
}//初始化双向循环链表
void newLnode(linklist*p)
{
*p=(linklist)malloc(LEN);//新节点
if(!p)
{
printf("申请节点失败");
exit(0);
}
(*p)-info=(linknode)malloc(TEALEN);
}
void prin(linklist * L)
{
if(L==NULL)
{
printf("没有可以显示的信息\n");
return;
}
linklist p=(*L)-next;
// printf("********************************************************************************\n");
printf("教师编号 教师姓名 工作量排名 工作总量\n\n");
while (p!=*L)
{
printf("%7s%9s%10d%10d\n",p-no,p-info-name,p-info-pos,p-info-total);
p=p-next;
}
}
void main()
{
linklist input(linklist L);
linklist sort(linklist L);
int j;//用来判断是否结束
linklist L;
initlist(L);
do{
system("cls");//清屏函数
printf(" ★--- 您好,欢迎进入教师工作量统计系统! ---★\n");
printf("================================================================================\n");
printf( " -------- ☆ 1.输入教师工作量信息 ☆-------- \n\n"
" -------- ☆ 2.进行教师工作量排序 ☆-------- \n\n"
" -------- ☆ 3.显示教师工作量情况 ☆-------- \n\n"
" -------- ☆ 0.退出 ☆-------- \n\n");
printf("================================================================================\n");
printf("请在0-3中选择以回车键结束:\n\n");
scanf("%d",j);
switch(j) {
case 1:
L=input(L);
prin(L);
printf("录入结束\n");
system("pause");
break;
case 2:
L=sort(L);
printf("排序成功\n");
system("pause");
break;
case 3:
prin(L);
system("pause");
break;
case 0:;
break;
}
}while(j!=0);
printf("谢谢使用,再见!\n");
}//主函数结束
linklist input(linklist L)
{
linklist workload(linklist p);
linklist adworkload(linklist p);
linklist searinsert(linklist L,linklist p);
linklist sort(linklist L);
int flag=0;
char no[10];
linklist p;
p=L-next;
for(;;)
{
if(flag==1)
break;
printf("请输入教师编号输入@结束:\n\n");
scanf("%s",no);
if(no[0]=='@')
{
flag=1;
break;
}
while (p!=L)//当链表不空时
{
if (strcmp(p-no,no)==0)
{
printf("该教师编号已存在,输入需要增加的工作量\n\n");
p-prior-next=p-next;
p-next-prior=p-prior;//删除P,
p=adworkload(p);//修改P中的详细信息info指针域的内容
L=searinsert(L,p);//重新查找P的位置插入链表L中
return L;
}
p=p-next;
}//跳出循环则该教师编号第一次输入
newLnode(p);
strcpy(p-no,no);
printf("请输入教师姓名:\n");
scanf("%s",p-info-name);
p=workload(p);
L=searinsert(L,p);
}
return L;
}
linklist adworkload(linklist p)
{
int a;
printf("请输入增加的授课工作量:\n");
scanf("%d",a);
p-info-lesson+=a;
printf("请输入增加的实验工作量:\n");
scanf("%d",a);
p-info-exper+=a;
printf("请输入增加的课程设计工作量:\n");
scanf("%d",a);
p-info-cdesign+=a;
printf("请输入增加的毕业设计工作量:\n");
scanf("%d",a);
p-info-gdesign+=a;
//p-info-pos=0;
p-info-total=p-info-lesson+p-info-exper+p-info-cdesign+p-info-gdesign;//求总工作量
return p;
}
linklist workload(linklist p)
{
printf("请输入该教师的授课工作量:\n");
scanf("%d",(p-info-lesson));
printf("请输入该教师的实验工作量:\n");
scanf("%d",(p-info-exper));
printf("请输入该教师的课程设计工作量:\n");
scanf("%d",(p-info-cdesign));
printf("请输入该教师的毕业设计工作量:\n");
scanf("%d",(p-info-gdesign));
p-info-pos=0;
p-info-total=p-info-lesson+p-info-exper+p-info-cdesign+p-info-gdesign;//求总工作量
return p;
}
linklist searinsert(linklist L,linklist p)
{//将P放置L中合适的位置
linklist tra;//遍历指针
linklist x;//P插入位置的前一个节点指针
tra=L-next;//指向第一个节点
if ((L-next==L)||(p-info-totaltra-info-total)) //第一次插入或者大于表头的情况
{
x=L;//插入表头
}
else if (p-info-totalL-prior-info-total) //小于表尾的情况
{
x=L-prior;//插入表尾
}
else
{ while (p-info-totaltra-info-total)
tra=tra-next;
x=tra-prior;//正常查找情况
}
//将P接到X后面
p-next=x-next;
p-prior=x;
x-next=p;
p-next-prior=p;
return L;
}
linklist sort(linklist L)
{
linklist sortfisrtlast(linklist L,linklist first,linklist last,int n);
int i;
for(i=0;iMAX;i++)
SAME[i]=0;//初始化数组SAME[MAX]
linklist p,first,last;
int x,n=1,k;
p=L-next;
while (p!=L)
{
x=1;
while ((p-next-info-total!=p-info-total)p!=L)
{
p-info-pos=n;
p=p-next;
n++;
}
if (p==L)
return L;
else
while ((p-next-info-total==p-info-total)p!=L)
{
k=n;
if (x==1)
{
//k=n;
first=p;
}
p-info-pos=k;
x++;
p=p-next;
p-info-pos=k;
//保存X
SAME[k]=x;
}
n+=x-1;
if (p==L)
return L;
else
{
last=p;
p=last-next;
L=sortfisrtlast(L,first,last,k);//调用fisrt last函数
}
}
}
linklist sortfisrtlast(linklist L,linklist first,linklist last,int n)
{
if (first==last)
return L;
linklist head,posa,posb,p,t;
linklist tra;//遍历指针
linklist x;//P插入位置的前一个节点指针
posa=first-prior;//接入位置a
posb=last-next;//接入位置b
posa-next=last-next;
last-next-prior=posa;
last-next=NULL;
first-prior=NULL;//删除这段
initlist(head);
p=first;
while (p!=NULL)
{
tra=head-next;
if ((head-next==head)||strcmp(p-no,tra-no)0)//第一次插入或者小于当前节点
x=head;
else if (strcmp(p-no,head-prior-no)0)
x=head-prior;
else
{
while(strcmp(p-no,tra-no)0)
tra=tra-next;
x=tra-prior;
}
t=p;//将P接到X后
p=p-next;
t-next=x-next;
t-prior=x;
x-next=t;
t-next-prior=t;
}
printf("********************************************************************************\n");
// printf("================================================================================\n");
printf("工作量名次相同的教师名单:(按编号排序)\n\n");
printf("名次为%d教师共有%d名\n\n",n,SAME[n]);
prin(head);
first=head-next;
last=head-prior;
posa-next=first;
first-prior=posa;
posb-prior=last;
last-next=posb;
return L;
}
C++写的公司员工信息管理系统(可加分)
#includeiostream
#includestring
using namespace std;
class employee
{
public:
string name;
string sex;
string techang;
string xuexing;
string xingzuo;
string attend;
string getin;
string birthday;
int static number;
int grade;
int money;
long call;
employee(){number++;grade=1;};
void virtual input(){};
void show()
{
cout"姓名:"name" ";
cout"性别:"sex" ";
cout"年月:"birthday" ";
cout"特长:"techang" ";
cout"血型:"xuexing" ";
cout"星座:"xingzuo" ";
cout"参加公司时间:"attend" ";
cout"进入公司时间:"getin" ";
cout"月薪:"money" ";
cout"编号:"number" ";
cout"级别:"grade" "endl;
};
};
int employee::number=0;
class technician:public employee
{
public:
technician(){money=3000;};
void input()
{
cout"姓名:";cinname;coutendl;
cout"性别:";cinsex;coutendl;
cout"年月:";cinbirthday;coutendl;
cout"特长:";cintechang;coutendl;
cout"血型:";cinxuexing;coutendl;
cout"星座:";cinxingzuo;coutendl;
cout"参加公司时间:";cinattend;coutendl;
cout"进入公司时间:";cingetin;coutendl;
};
};
class manger:public employee
{
public:
int x;
void input()
{
int x;
cout"姓名:";cinname;coutendl;
cout"性别:";cinsex;coutendl;
cout"经理类型(1 总经理,2 销售经理,3 技术经理):";cinx;
switch(x)
{
int y,z;
case 1:
money=10000;break;
case 2:
cout"销售额:";ciny;money=4000+y/20;break;
case 3:
cout"奖金:";cinz;money=6000+z;break;
};
cout"年月:";cinbirthday;coutendl;
cout"特长:";cintechang;coutendl;
cout"血型:";cinxuexing;coutendl;
cout"星座:";cinxingzuo;coutendl;
cout"参加公司时间:";cinattend;coutendl;
cout"进入公司时间:";cingetin;coutendl;
};
};
class saleman:public employee
{
public:
int m;
void input()
{
cout"姓名:";cinname;coutendl;
cout"性别:";cinsex;coutendl;
cout"年月:";cinbirthday;coutendl;
cout"销售额:";cinm;money=m;coutendl;
cout"特长:";cintechang;coutendl;
cout"血型:";cinxuexing;coutendl;
cout"星座:";cinxingzuo;coutendl;
cout"参加公司时间:";cinattend;coutendl;
cout"进入公司时间:";cingetin;coutendl;
};
};
void main()
{
int n;
manger a;
technician b;
saleman c;
cout"***通信09-3***孙太川***20092258****"endl;
cout"***********************************"endl;
cout"* 主菜单 *"endl;
cout"* 1 输入职工信息 *"endl;
cout"* 2 查询职工信息 *"endl;
cout"* 3 退出系统 *"endl;
cout"***********************************"endl;
while(1)
{
cout"选择你所需要的菜单:";
cinn;
if(n==3)break;
switch(n)
{
int w;
case 1:
cout"选择你所需要输入的职工类型:"endl;
cout"(1 经理,2 技术人员,3 销售人员):";
cinw;
switch(w)
{
case 1:
a.input();break;
case 2:
b.input();break;
case 3:
c.input();break;
};
case 2:
int u;
cout"编号:";cinu;
switch(u)
{
case 1:
a.show();break;
case 2:
b.show();break;
case 3:
c.show();break;
};
};
};
}
用C++设计一个员工类
我找了一个学生管理系统的源代码,解释员工类 #includestdio.h
#includemalloc.h
typedef struct
{char name[10];br int number;br char sex[20];br char age[20];br}stu;
typedef struct
{stu *elem;brint length;br}sqlist;
int found(sqlist l,int x)
{int i;brfor(i=0;il.length;i++)br if(l.elem[i].number==x) break;br if(i==l.length)br { printf("无此学生重新输入学号\n");return -1;}
else return i;}
void add(sqlist l)
{int x,i;brprintf("增加多少名学生\n");brscanf("%d",x);brl.elem=(stu*)realloc(l.elem,sizeof(stu)*(l.length+x));brfor(i=l.length;ix+l.length;i++)br{printf("\n输入学生学号、性别、年龄、姓名:");brscanf("%d",l.elem[i].number);brscanf("%s",l.elem[i].sex);brscanf("%s",l.elem[i].age);brscanf("%s",l.elem[i].name);br}
l.length=l.length+x;}
void del(sqlist l)
{int x,i,j=1;brstu *p;brwhile(j)br{printf("输入学号:\n");br scanf("%d",x);bri=found(l,x);brif(i==-1)brcontinue;brfor(p=l.elem+i;pl.elem+l.length-1;p++)br*p=*(p+1);brl.length--;brprintf("输入0退出删除系统,其他继续\n");brscanf("%d",j);}}
void change(sqlist l)
{int i,j=1,x;br while(j)br{printf("输入学号:\n");br scanf("%d",x);bri=found(l,x);brif(i==-1)brcontinue;brprintf("输入新学生学号、性别、年龄、姓名:\n");brscanf("%d",l.elem[i].number);brscanf("%s",l.elem[i].sex);brscanf("%s",l.elem[i].age);brscanf("%s",l.elem[i].name);br printf("输入0退出修改系统,其他继续\n");brscanf(" %d",j);}}
void display(sqlist l)
{int i;br printf("学号 姓名 性别 年龄\n"); br for(i=0;il.length;i++)br {printf("%d ",l.elem[i].number);br printf("%s ",l.elem[i].name);br printf("%s ",l.elem[i].sex);br printf("%s ",l.elem[i].age);br printf("\n");br }
}
void main()
{sqlist l;brint i,j,k=1,m;br printf("初始化,输入学生个数:\n");br scanf("%d",m);br l.elem=(stu*)malloc(sizeof(stu)*m);br l.length=m;br printf("请输入%d个学生信息:\n",m);brfor(i=0;im;i++)br{printf("\n输入学生学号、性别、年龄、姓名:");brscanf("%d",l.elem[i].number);brscanf("%s",l.elem[i].sex);brscanf("%s",l.elem[i].age);brscanf("%s",l.elem[i].name);br}while(k)
{printf("\n____________________ \n");br printf("| 1---增加学生信息 |\n");br printf("| 2---删除学生信息 |\n");br printf("| 3---修改学生信息 |\n");br printf("| 4---显示学生信息 |\n");br printf("| 0---退出 |\n");br printf("| ___________________|");br scanf(" %d",j);brswitch (j)br{ case 1:add(l);break;br case 2:del(l);break;br case 3:change(l);break;br case 4:display(l);break;br default: k=0;}
}
}
c员工管理系统源代码的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于c语言职工管理系统源代码、c员工管理系统源代码的信息别忘了在本站进行查找喔。
版权说明:如非注明,本站文章均为 AH站长 原创,转载请注明出处和附带本文链接;
相关推荐
- 05-12网页设计需要学什么,网页设计学什么语言
- 05-07pb超级报表源代码(pb报表工具)[20240507更新]
- 05-07简历源代码可以上传照片的简单介绍[20240507更新]
- 05-07广告切换源代码免费下载(广告切换源代码免费下载安装)[20240507更新]
- 05-06阁楼网源代码(阁楼是什么网站)[20240506更新]
- 05-06源代码管理资源管理器(资源管理器运行代码)[20240506更新]
- 05-06人脸识别源代码pdf的简单介绍[20240506更新]
- 05-06包含超市管理系统java源代码的词条[20240506更新]
- 05-06商城app源代码免费(商城App源码)[20240506更新]
- 05-06包含游戏源代码不同的模式的词条[20240506更新]
取消回复欢迎 你 发表评论:
- 标签列表
- 最近发表
- 友情链接