工资管理系统课程设计Word下载.docx
《工资管理系统课程设计Word下载.docx》由会员分享,可在线阅读,更多相关《工资管理系统课程设计Word下载.docx(47页珍藏版)》请在冰点文库上搜索。
修改模块
输出模块
输入模块
降序排序
生序排序
姓名查询
编号查询
修改扣款
修改基本工资
修改姓名
修改编号
一、总体设计
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