C++实现简单的职工管理系统实训代码_C 语言

本文实例为大家分享了C++职工管理系统实例代码

1.单个职工的头文件
staff.h 

#ifndef STAFF_H_INCLUDED
#define STAFF_H_INCLUDED

//结构体创建
struct staff
{
  char ID[10];
  char name[10];
  char sex[10];
  int pay;
  int reward;
  int factpay;
};
//自定义结构体

typedef struct staff staff;
//单个职工信息创建
staff Createstaff();
//单个职工信息输出
void Displaystaff(staff staff);
//修改职工信息
void updatestaff(staff *Staff);

#endif // STAFF_H_INCLUDED

单个职工的cpp文件
staff.cpp

#include <stdio.h>
#include <stdlib.h>
#include "staff.h"

staff Createstaff()
{
  staff staff;
  printf("-----------ID-----------\n");
  scanf("%s", staff.ID);
  printf("-----------name-----------\n");
  scanf("%s", staff.name);
  printf("-----------sex-----------\n");
  scanf("%s", staff.sex);
  printf("-----------pay-----------\n");
  scanf("%d", &staff.pay);
  printf("-----------reward-----------\n");
  scanf("%d", &staff.reward);
  staff.factpay = staff.pay + staff.reward;
  printf("\n");

  return staff;

}

void Displaystaff(staff staff)
{
  printf("%10s", staff.ID);
  printf("%10s", staff.name);
  printf("%10s", staff.sex);
  printf("%10d", staff.pay);
  printf("%10d", staff.reward);
  printf("%10d", staff.factpay);
  printf("\n");
}

void updatestaff(staff *Staff)
{
  printf("-----请显示要修改的数据--------\n");
  Displaystaff(*Staff);

  printf("-------请输入要修改的数据---------");
  printf("-----------pay-----------\n");
  scanf("%d", &Staff->pay);
  printf("-----------reward-----------\n");
  scanf("%d", &Staff->reward);
  Staff->factpay = Staff->pay + Staff->reward;
  printf("\n");

}

 2.链表的创建
链表的头文件
linklist.h 

#ifndef LINKLIST_H_INCLUDED
#define LINKLIST_H_INCLUDED
#include "staff.h"
//链表结点创建
struct Node
{
  struct staff Staff;
  struct Node *next;
};
//自定义结点

typedef struct Node node;
typedef struct Node *linklist;
//创建链表
node *Createlinklist();
//输出链表中的数据
void Displaylinklist(node *head);
//按职工号查找职工
node *searchnode(node *head, char ID[]);
//按姓名查找职工
void searchnodebyname(node *head, char name[]);
//删除职工
void delenode(linklist head, char ID[]);
//插入职工
void insertnode(linklist head, staff Staff);
//链表销毁
void distroylinklist(linklist head);

#endif // LINKLIST_H_INCLUDED

链表创建的源程序
linklist.cpp

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "staff.h"
#include "linklist.h"
node *Createlinklist()
{
  node *head, *p;

  head = (node *)malloc(sizeof(node));
  head->next = NULL;
  staff a[100] = {{"11111", "mmm", "f", 12000, 2000, 14000},
        {"22222", "aaa", "m", 13000, 3000, 16000},
        {"33333", "sss", "f", 15000, 3000, 18000},
        {"44444", "fff", "m", 17000, 8000, 25000},
        {"55555", "ggg", "f", 20000, 5000, 25000}};
  for(int i = 0; i<5; i++)
  {
    p = (node *)malloc(sizeof(node));
    p->Staff = a[i];

    p->next = head->next;
    head->next = p;
  }
  return head;
}

void Displaylinklist(node *head)
{
  linklist p;
  p = head->next;
  while(p!=NULL)
  {
    Displaystaff(p->Staff);
    p = p->next;
  }
}
node *searchnode(node *head, char ID[])
{
  linklist p;
  p = head;
  while(p!=NULL&&strcmp(p->next->Staff.ID, ID)!=0)
  {
    p = p->next;
  }
  return p->next;
}

void searchnodebyname(node *head, char name[])
{
  linklist p;
  p = head;
  while((p!=NULL)&&(strcmp((p->next)->Staff.name, name)!=0))
  {
    p = p->next;
  }
  printf("-----´ËÈËΪ---------\n");

  printf("%s", p->next->Staff.name);
  printf("\n");

}

void delenode(linklist head, char ID[])
{
  linklist p;
  p = head;
  while(p->next&&(strcmp(p->next->Staff.ID, ID)!=0))
  {
    p = p->next;
  }
  if(p->next)
  {

    p->next = p->next->next;
  }
  else
  {
    printf("=====NO FOUND========\n");
  }
}
void insertnode(linklist head, staff Staff)
{
  linklist p;
  p = (node *)malloc(sizeof(node));
  p->Staff = Staff;

  p->next = head->next;
  head->next = p;

}
void distroylinklist(linklist head)
{
  linklist p;
  p = head;
  while(p!=NULL)
  {
    p = p->next;
    free(p);
  }
}

3.文件存盘
file.h

#ifndef FILE_H_INCLUDED
#define FILE_H_INCLUDED
#include "linklist.h"
#include "staff.h"
//职工信息存盘
void saveinformation(linklist head );
//职工信息加载
void loadinformation(linklist head );

#endif // FILE_H_INCLUDED

file.cpp
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include "file.h"
#include "linklist.h"
#include "staff.h"

void saveinformation(linklist h )
{
  FILE *fp;
  linklist p;

  if ( (fp = fopen("stu.txt","w") ) == NULL)
  {
    printf("Failure to open stu.txt!\n");
    exit(0);
  }

  for ( p = h->next; p; p=p->next )
  {
    fwrite( &(p->Staff), sizeof(node), 1, fp);
  }

  fclose(fp);
}

void loadinformation( linklist h )
{
  FILE *fp;
  staff nodeBuffer;

  if ((fp = fopen("stu.txt","r")) == NULL)
  {
    printf("\n\t数据文件丢失或为首次运行, 将加载测试数据\n");
    return ;
  }

   while( fread(&nodeBuffer, sizeof(node), 1, fp)!=0 )
  {
    insertnode(h, nodeBuffer);
  }

}

4.主函数
mainmeun.cpp

#include <stdio.h>
#include <stdlib.h>
#include "linklist.h"
#include "staff.h"
#include "file.h"
void mainmeun(linklist head);
void searchmenu(linklist head);

int main(void)
{
  linklist head=NULL;
  //int n;

  //printf("------请输入你要存的数据----------\n");
  //scanf("%d", &n);
  head = Createlinklist();
  system("cls");
  //Displaylinklist(head);

  mainmeun(head);
  printf("\n\n");
  //loadinformation(head);
  //saveinformation(head);
  return 0;
}
void mainmeun(linklist head)
{
  linklist p;

  char ID[10];
  //char name[10];
  staff Staff;
  int selection;
  int flag = 1;
  do
  {
    printf("=================职工管理系统===================\n");
    printf("==========1.链表输出=====2.数据查询=====\n");
    printf("=======3.数据删除===4.数据修改=====5.添加数据======\n");
    printf("=======6.链表销毁===7.信息存盘=====8.放弃存盘=====\n");
    printf("==================================================\n");

    printf("======请选择功能(1~8):");
    scanf("%d", &selection);
    switch(selection)
    {
    case 1:
      Displaylinklist(head);
      break;
    case 2:
      searchmenu(head);

      break;
    case 3:
      printf("=========请输入工号==========\n");
      scanf("%s", ID);
      delenode(head, ID);
      break;
    case 4:
      printf("=========请输入工号==========\n");
      scanf("%s", ID);
      p = searchnode(head, ID);
      updatestaff(&(p->Staff));

      break;
    case 5:
      printf("========添加数据=========");
      Staff = Createstaff();
      insertnode(head, Staff);
      break;
    case 6:
      distroylinklist(head);
      break;
    case 7:
      loadinformation(head);
      saveinformation(head);

      break;
    case 8:
      flag = 0;
      break;

    }
  }while(flag == 1);
  printf("========BYE=====BYE======");

}
void searchmenu(linklist head)
{
  linklist p;
  int flag = 1;
  char ID[10];
  char name[10];

  do
  {
    printf("=========查找菜单===========\n");
    printf("===1.ID======2.name====3.退出====\n");
    printf("=================================\n");

    int selection;
    printf("==请选择功能(1~3):");
    scanf("%d", &selection);
    switch(selection)
    {
    case 1:
      printf("=====请输入ID=======\n");
      scanf("%s", ID);
      p = searchnode(head, ID);
      Displaystaff(p->Staff);
      break;

    case 2:
      printf("=====请输入name======\n");
      scanf("%s", name);
      searchnodebyname(head, name);
      break;

    case 3:
      flag = 0;
      break;
    }
    system("pause");
    system("cls");

  }while(flag == 1);
}

以上就是本文的全部内容,希望对大家实现C++职工管理系统有所帮助,启发。

推荐几篇文章:

C++实现简单的图书管理系统

C++实现简单的职工信息管理系统

C++基础学生管理系统

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索C++管理系统
, C++职工管理系统
, C++职工管理
C++实训
c语言atm简单实训代码、c语言实现简单数据库、链表c语言实现 简单、sql语言实训、c语言实训总结,以便于您获取更多的相关知识。

时间: 2024-11-05 14:58:20

C++实现简单的职工管理系统实训代码_C 语言的相关文章

C++简单QQ程序服务器端的实现代码_C 语言

本文实例为大家分享了C++简单QQ程序服务器端的实现代码,供大家参考,具体内容如下 // ServerDlg.cpp : implementation file // #include "StdAfx.h" #include "Server.h" #include "ServerDlg.h" #ifdef _DEBUG #define new DEBUG_NEW #undef THIS_FILE static char THIS_FILE[] =

C#实现简单的双色球抽取中奖号码代码_C#教程

废话不多说,直接给大家贴代码,我我就是这么狠... 关键代码如下所示: int[] ss = new int[6]; Random s = new Random(); Console.WriteLine("双色球随机:"); for (int i = 0; i < 6; i++) { bool b = true; int a = s.Next(1, 34); for (int j = 0; j < i; j++) { if (a == ss[j]) { b = false;

VC++简单实现关机、重启计算机实例代码_C 语言

本文以一个实例形式介绍了VC++简单实现关机.重启计算机的方法,代码比较实用,有一定的参考价值.完整实例代码如下: void CWebBrowserView::OnMenuShutdown() { // TODO: 在此添加命令处理程序代码 if (AfxMessageBox("确定要关机吗?",MB_YESNO) == IDYES) { HANDLE hToken; TOKEN_PRIVILEGES tkp; // Get a token for this process. if (

使用C++制作简单的web服务器(续)_C 语言

增加功能: 1.从文件中读取网页并返回给客户端,而不是把网页代码写死在代码中. 局限: 1.还不能根据URL地址中的参数,访问指定页面 2.仍然是单线程 复制代码 代码如下: //*****************************************************************************//@ProjectName      ZYhttpd//@Description      my http server//@Author           Ni

简单介绍C++中变量的引用_C 语言

什么是变量的引用 对一个数据可以使用"引用(reference)",这是C++对C的一个重要扩充,引用是一种新的变量类型,它的作用是为一个变量起一个别名.假如有一个变量a,想给它起一个别名b,可以这样写: int a; //定义a是整型变量 int &b=a; //声明b是a的引用 以上语句声明了b是a的引用,即b是a的别名.经过这样的声明后,a或b的作用相同,都代表同一变量. 注意: 在上述声明中,&是引用声明符,并不代表地址.不要理解为"把a的值赋给b的地

C语言简单实现计算字符个数的方法_C 语言

本文实例讲述了C语言简单实现计算字符个数的方法.分享给大家供大家参考.具体如下: char_counting.c如下: #include<stdio.h> int main() { long nc; nc = 0; while(getchar() != '0') { ++nc; } printf("%ld\n", nc); } 编译和使用下: 复制代码 代码如下: gcc char_counting.c -o char_counting.o   一种通常的调用方式: 复制代

C++实现简单的希尔排序Shell Sort实例_C 语言

本文以实例形式讲述了基于C++实现简单的希尔排序Shell Sort的方法,是一个很经典的算法,具体实现代码如下: #include <iostream> using namespace std; void ShellSort(int* iArray,int length) { //初始化jump等于length int jump = length; //标记本趟检测是否进行了交换, // 若进行了 则还有下次从头开始的检测, // 否则停止,继续改变jump的值 做另一趟排序 bool is

C++实现顺序排序算法简单示例代码_C 语言

本文实例讲述了最直接的顺序排序法VC++示例代码,还记得以前上学时候这是计算机的必考题,而且在排序算法中,顺序排序似乎是最简单的了,也是最容易掌握的.现在列出来让大家重新回顾一下! 具体代码如下: //顺序排序 void InsertSort(int r[], int n){ for (int i=2; i<n; i++){ r[0]=r[i]; //设置哨兵 for (int j=i-1; r[0]<r[j]; j--) //寻找插入位置 r[j+1]=r[j]; //记录后移 r[j+1]

简单掌握C++中的函数模板_C 语言

1.函数模板的声明和模板函数的生成 1.1函数模板的声明函数模板可以用来创建一个通用的函数,以支持多种不同的形参,避免重载函数的函数体重复设计.它的最大特点是把函数使用的数据类型作为参数. 函数模板的声明形式为: template<typename 数据类型参数标识符> <返回类型><函数名>(参数表) { 函数体 } 其中,template是定义模板函数的关键字:template后面的尖括号不能省略:typename(或class)是声明数据类型参数标识符的关键字,用