当前位置:首页 > 代码 > 正文

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站长 原创,转载请注明出处和附带本文链接;

本文地址:http://ahzz.com.cn/post/16986.html


取消回复欢迎 发表评论:

分享到

温馨提示

下载成功了么?或者链接失效了?

联系我们反馈

立即下载