工资管理系统课程设计Word下载.docx

上传人:b****1 文档编号:834141 上传时间:2023-04-29 格式:DOCX 页数:47 大小:272.78KB
下载 相关 举报
工资管理系统课程设计Word下载.docx_第1页
第1页 / 共47页
工资管理系统课程设计Word下载.docx_第2页
第2页 / 共47页
工资管理系统课程设计Word下载.docx_第3页
第3页 / 共47页
工资管理系统课程设计Word下载.docx_第4页
第4页 / 共47页
工资管理系统课程设计Word下载.docx_第5页
第5页 / 共47页
工资管理系统课程设计Word下载.docx_第6页
第6页 / 共47页
工资管理系统课程设计Word下载.docx_第7页
第7页 / 共47页
工资管理系统课程设计Word下载.docx_第8页
第8页 / 共47页
工资管理系统课程设计Word下载.docx_第9页
第9页 / 共47页
工资管理系统课程设计Word下载.docx_第10页
第10页 / 共47页
工资管理系统课程设计Word下载.docx_第11页
第11页 / 共47页
工资管理系统课程设计Word下载.docx_第12页
第12页 / 共47页
工资管理系统课程设计Word下载.docx_第13页
第13页 / 共47页
工资管理系统课程设计Word下载.docx_第14页
第14页 / 共47页
工资管理系统课程设计Word下载.docx_第15页
第15页 / 共47页
工资管理系统课程设计Word下载.docx_第16页
第16页 / 共47页
工资管理系统课程设计Word下载.docx_第17页
第17页 / 共47页
工资管理系统课程设计Word下载.docx_第18页
第18页 / 共47页
工资管理系统课程设计Word下载.docx_第19页
第19页 / 共47页
工资管理系统课程设计Word下载.docx_第20页
第20页 / 共47页
亲,该文档总共47页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

工资管理系统课程设计Word下载.docx

《工资管理系统课程设计Word下载.docx》由会员分享,可在线阅读,更多相关《工资管理系统课程设计Word下载.docx(47页珍藏版)》请在冰点文库上搜索。

工资管理系统课程设计Word下载.docx

修改模块

输出模块

输入模块

降序排序

生序排序

姓名查询

编号查询

修改扣款

修改基本工资

修改姓名

修改编号

一、总体设计

1、功能模块设计

(1)主函数程序流程图

main()

降序

升序

保存文件

排序

删除职工信息

按职工姓名

按职工编号

查询职工信息

插入职工信息

编号

姓名

性别

基本工资

扣款

修改职工信息

输出职工信息

制作工资表

菜单

Case8

Case1

Case7

Case6

Case5

Case4

Case3

Case2

switch

(2)

高于10000

8000~10000

3500~8000

低于3500

结束

退出

Case0

(2)输入模块

跳出

开始

输入职工的信息

P->

next

next!

=NULL

While()是否继续输入

(3)输出模块

开始

结束输出

P是否为空

While()

P=P->

(4)修改模块

P是否NULL

输入要修改的职工编号k

查找有无该职工

不修改

是否修改

继续修改

开始

(5)插入模块

定义变量,申请内存

查找插入之后的编号

不存在

该编号之后的节点后移一位

输入要插入的职工信息

(6)

输出

定义变量

选择语句

编号查询

姓名查询

(7)

输入要删除的编号

查找该编号

是否继续删除

没有找到

将前一节点指针指向当前节点的下一节点

释放节点

(8)

选择

Case1

Case2

(9)计算税金

{(基本工资)--(扣款)}*税率-速扣数=个人所得税。

  

以总工资5105元为例,三险一金105为例  {5105-105-3500}X0.03-0=45元  

2011年9月1日起调整后的7级超额累进税率

全月应纳税所得额税率速算扣除数(元)

全月应纳税额不超过1500元3%0

全月应纳税额超过1500元至4500元10%105

全月应纳税额超过4500元至9000元20%555

全月应纳税额超过9000元至35000元25%1005

全月应纳税额超过35000元至55000元30%2755

全月应纳税额超过55000元至80000元35%5505

全月应纳税额超过80000元45%13505

三、数据结构设计

职工信息信息结构体

structworker//定义数据结构//

{

charno[11];

//编号//

charname[15];

//姓名//

charxb[10];

//性别//

doublejbgz;

//基本工资//

doublekoukuan;

//扣款//

doubleyfgz;

//应发工资//

doubleshuijin;

//税金//

doublesfgz;

//实发工资//

charpost[10];

//职位//

structworker*next;

};

typedefstructworkerSTU;

//结构体类型名///

四、函数功能描述

intmenu_select(void);

//主菜单//

STU*append(STU*head);

//添加记录//

STU*appendNode(STU*head);

voidlist(STU*head);

//显示所有数据//

STU*modify(STU*head);

//修改职工记录//

STU*modifyNode(STU*head);

void*search(STU*head);

//查询职工信息//

void*no(STU*head);

//编号查询//

void*name(STU*head);

//姓名查询//

STU*dele(STU*head);

//删除职工信息//

STU*deleNode(STU*head,chark[11]);

void*save(STU*head);

//保存文件//

STU*insert(STU*head);

//插入职工信息//

STU*tax(STU*head);

//计算税金//

STU*calc(STU*head);

//计算应发工资//

STU*total(STU*head);

//计算实发工资//

STU*sort(STU*head);

//对职工信息进行排序//

STU*insort(STU*head);

//升序函数//

STU*desort(STU*head);

//降序函数//

void*index(STU*head);

//分类统计//

void*index1(STU*head);

void*index2(STU*head);

void*index3(STU*head);

void*index4(STU*head);

intuser_ID();

//登录账户函数//

STU表示结构体类型名

Head表示链表的头结点

5、源代码分析

6、⑴程序预处理

包括加载头文件,定义结构体、常量和变量,并对它们进行初始化工作。

#include<

stdio.h>

stdlib.h>

conio.h>

string.h>

memory.h>

windows.h>

⑵主函数main()

voidmain()

{intch;

chara;

STU*head=NULL;

system("

color02"

);

//背景色/前景色的设置(0黑色、1蓝色、2绿色、3浅绿色、4红色、5紫色、6黄色、7白色、8灰色、9淡紫色、A淡绿色、B淡浅绿色、C淡红色、D淡紫色、E淡黄色、F亮白色)//

printf("

&

****&

\n"

*欢迎使用工资管理系统*\n"

************************************\n"

**************************表头***************************\n"

*实验名称:

工资管理系统*\n"

*实验制作成员:

程新华、马晓辉、马存祥、赵宽祖*\n"

*组长:

程新华*\n"

*测试员:

马晓辉*\n"

*调试:

*实验制作时间:

*\n"

*修改时间:

*********************************************************\n"

&

********按任意键继续********&

"

a=getchar();

while(!

a);

cls"

user_ID();

while

(1)

{

ch=menu_select();

switch(ch)

case1:

head=append(head);

break;

//制作工资表//

case2:

list(head);

//输出所有的职工的信息//

case3:

head=modify(head);

//修改职工信息//

case4:

head=insert(head);

case5:

search(head);

case6:

head=dele(head);

//删除职工信息//

case7:

head=sort(head);

case8:

index(head);

case0:

exit(0);

//退出//

default:

printf("

Inputerror!

break;

}

}六、运行结果

1、主界面

成绩管理系统主菜单

2、输入学生记录

3、显示记录

4、修改记录

5、插入记录

6、删除记录

7、对职工信息排序

(1)升序

(2)降序

7、源程序代码

//结构体类型名//

/******函数原型*********/

voidindex(STU*head);

voidindex1(STU*head);

voidindex2(STU*head);

voidindex3(STU*head);

voidindex4(STU*head);

//**************************主函数****************************//

}

//*************菜单选项*****************//

intmenu_select(void)

*************主菜单*************************&

*1.制作工资表*\n"

*2.输出所有的职工的信息*\n"

*3.修改职工的信息*\n"

*4.插入职工信息*\n"

*5.查询职工的信息*\n"

*6.删除职工的信息*\n"

*7.对职工信息进行排序*\n"

*8.分类统计*\n"

*0.退出*\n"

********************************************&

请输入你的选择:

scanf("

%d"

&

ch);

returnch;

//***********制作工资表***************************//

STU*append(STU*head)

{charc;

do{head=appendNode(head);

//向链表末尾添加一个节点//

确认添加新纪录请按Y/y!

"

其他键视为不添加!

你想添加一个新的记录吗(Y/N)?

%c"

c);

}while(c=='

Y'

||c=='

y'

returnhead;

STU*appendNode(STU*head)

STU*p=NULL;

STU*pr=head;

p=(STU*)malloc(sizeof(STU));

//为新添加的节点申请内存//

if(p==NULL)//若申请内存失败,则输出错误信息,退出程序//

Noenoughmemorytoalloc"

exit(0);

if(head==NULL)//若原链表为空,则将新建节点置为首节点//

head=p;

else//若原链表为非空,则将新建节点添加到表尾*/

while(pr->

next!

=NULL)//若未到表尾,则继续移动指针pr,直到pr指向表尾//

pr=pr->

next;

pr->

next=p;

//将新建节点添加到链表的末尾//

pr=p;

//让pr指向新建节点//

输入职工的编号:

%s"

p->

no);

输入职工的姓名:

name);

输入职工的性别:

xb);

输入职工的职位:

post);

输入职工的月基本工资:

%lf"

&

p->

jbgz);

输入职工的月扣款数:

koukuan);

p->

sfgz=0;

//初始实发工资为0//

shuijin=0;

//初始税金为0//

yfgz=0;

//初始应发工资为0//

next=NULL;

//将新建节点置为表尾//

//********************输出职工的信息****************************//

voidlist(STU*head)

{

STU*p=head;

if(p==NULL)

工资表为空请重新输入!

!

else

{head=calc(head);

head=tax(head);

head=total(head);

*************************************工资表*******************\n"

编号\t姓名\t性别\t职位\t基本工资\t扣款\t应发工资\t实发工资"

while(p!

=NULL)

{printf("

%s\t%s\t%s\t%s\t%.2lf\t%.2lf\t%.2lf\t%.2lf\n"

p->

no,p->

name,p->

xb,p->

post,p->

jbgz,p->

koukuan,p->

yfgz,p->

sfgz);

p=p->

//*******************修改职工信息*******************//

STU*modify(STU*head)

charc;

STU*p=NULL;

STU*q=head;

do{p=modifyNode(head);

继续修改请按Y/y!

其他键视为不修改!

你想继续修改记录吗(Y/N)?

STU*modifyNode(STU*head)

{inti,j;

chark[11];

if(q==NULL)

请输入你想修改的职工的编号:

k);

while(q&

strcmp(q->

no,k)!

=0)//做比较判断//

q=q->

//没找到,指针后移继续查找//

if(q==NULL)//指针为空,说明没有找到//

Notfound!

returnhea

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 总结汇报 > 学习总结

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2