C语言实现简单职工信息管理系统

本文实例为大家分享了C语言实现职工信息管理系统的具体代码,供大家参考,具体内容如下

代码实现如下:

#include <stdio.h>//输入、输出指令
#include <malloc.h>//在内存中动态的分配size字节的存储区
#include <string.h>//字符串相关操作指令
#include <stdlib.h>//五种类型、一些宏和通用工具函数
#include<conio.h>//通过键盘产生的对应操作
#include <MEMORY.H>//存储访问头文件

typedef struct node
{    
     char   name[20];
     int    age;
     int    worktime;
     char   sex[20];
     char   marrige[20];
     int    grade;
     char   tired[20];
    struct  node *next;
}STU;

void output(STU *head);
STU *Create();
STU *findByName(STU *head,char *name);
STU *findByWorktime(STU *head,int worktime);
STU *findByGrade(STU *head,int grade);
void find(STU *head);
STU *insert(STU *head);
STU *findByNumEx(STU *head,char num[],STU **ppbefore);
STU *del(STU *head);
void update(STU *head);
void sort(STU *head);
void save_info(STU *head);
void copy();
STU *load_info();
char *password();

void main()
{      
    char *p;
     int i,n=0; 
       char a[40];
        printf("        \t\t*******欢迎使用职工信息管理系统********\n\n");  
        printf("        \t\t请输入口令:\n");
        printf("        \t\t----------:\n");
    for(i=0;i<3;i++)
    {   
        n=n+1;
        printf("        \t\t第%d次输入:",i+1);
        p=password();
       if(p!=NULL)
       {
           STU *head;
            int choice;
            int n;
            head=NULL;
             printf("\n        \t\t你是合法用户!\n\n");
        for (i = 0; i < 0x7FFFFFF; i++);
        for (i = 0; i < 0x7FFFFFF; i++);
        for (i = 0; i < 0x7FFFFFF; i++);
        system("cls");
        for(;;)
            {
                system("cls");
                printf("           \t\t*******职工信息管理系统********\n");
                printf("           \t\t* 1.输入职工信息              *\n");
                printf("           \t\t* 2.显示全部职工信息          *\n");
                printf("           \t\t* 3.查询职工信息              *\n");
                printf("           \t\t* 4.新增职工信息              *\n");
                printf("           \t\t* 5.删除职工信息              *\n");
                printf("           \t\t* 6.修改职工信息              *\n");
                printf("           \t\t* 7.对职工信息排序            *\n");
                printf("           \t\t* 8.保存当前信息到文件        *\n");
                printf("           \t\t* 9.备份信息资料到文件        *\n");
                printf("           \t\t* 10.从文件加载职工信息       *\n");
                printf("           \t\t* 0.退出系统                  *\n");
                printf("           \t\t*******************************\n");
                printf("           \t\t请选择(0-9):");
                scanf("%d",&choice);
                if(choice==0) break;
                switch(choice)
                {   
                    case 1: head=Create(); break;
                    case 2: output(head);break;
                    case 3:find(head);break;
                    case 4: head=insert(head); break;
                    case 5: head=del(head); break;
                    case 6: update(head);break;
                    case 7: sort(head);break;
                    case 8: save_info(head);break;
                    case 9: copy();break;
                    case 10:head=load_info();break;
                }
            printf("按任意键继续....");
            getch();
        }
        printf("           \t\t感谢您的使用,再见!\n");
        break;
        }
       else
       { 
           printf("\n        \t\t你是非法用户!\n\n");
           if(n==3)
            printf("           \t\t你的错误口令次数超过3次,程序关闭!\n");
       }
    }
}

STU *Create()
{
    STU *head,*pnew,*pend;
    head=NULL;
    printf("输入职工信息:\n姓名\t年龄\t工龄\t性别\t婚姻\t级别\t是否在职\n");
    for(;;) 
    {
        pnew=(STU *)malloc(sizeof(STU));
        scanf("%s",pnew->name);
        if(strcmp(pnew->name,"0")==0)
        {
            printf("员工信息录入完毕\n");
            break;
        }
        scanf("%d%d%s%s%d%s",&pnew->age,&pnew->worktime,pnew->sex,pnew->marrige,&pnew->grade,pnew->tired);
        pnew->next=NULL; 
        if(head==NULL){
            head=pnew;
            pend=pnew;
        }
        else{
            pend->next=pnew;
            pend=pend->next;
        }
    }
    return head;
}

void output(STU *head)
{
    STU *p;
    printf("职工信息如下:\n姓名\t年龄\t工龄\t性别\t婚姻\t级别\t是否在职\n");
    for(p=head;p!=NULL;p=p->next)
        printf("%s\t%d\t%d\t%s\t%s\t%d\t%s\n",p->name,p->age,p->worktime,p->sex,p->marrige,p->grade,p->tired);
}

void find(STU *head)
{
    STU *p;
    char name[20];
    int worktime,grade,i;
    int choice;
    system("cls");

for(;;)
    {
        system("cls");
        printf("           \t\t*******职工信息查询系统********\n");
        printf("           \t\t* 1.按职工姓名查找            *\n");
        printf("           \t\t* 2.按职工工龄查找            *\n");
        printf("           \t\t* 3.按职工级别查找            *\n");
        printf("           \t\t* 0.退出系统                  *\n");
        printf("           \t\t*******************************\n");
        printf("           \t\t请选择(0-3):");
        scanf("%d",&choice);
        if(choice==0) break;
        switch(choice)
        {   
            case 1:
                    printf("请输入职工姓名:");
                    scanf("%s",name);
                    p=findByName(head,name);break;
            case 2: 
                    printf("请输入职工工龄:");
                    scanf("%d",&worktime);
                    p=findByWorktime(head,worktime);break;
            case 3:
                    printf("请输入职工级别:");
                    scanf("%d",&grade);
                    p=findByGrade(head,grade);break;
        }
        if(p==NULL)
    {    
        printf("无与此职工相关的信息!\a\n");
    }
    else
    {
         if(choice==1)
         {    
             printf("职工信息如下:\n姓名\t年龄\t工龄\t性别\t婚姻\t级别\t是否在职\n"); 
             for(p=head;p!=NULL;p=p->next)
             {
                if(strcmp(p->name,name)==0)
                printf("%s\t%d\t%d\t%s\t%s\t%d\t%s\n",p->name,p->age,p->worktime,p->sex,p->marrige,p->grade,p->tired);
             }
         }
         else if(choice==2)
         {     
             printf("职工信息如下:\n姓名\t年龄\t工龄\t性别\t婚姻\t级别\t是否在职\n");
                for(p=head;p!=NULL;p=p->next)
                 {
                    if(p->worktime==worktime)
                    printf("%s\t%d\t%d\t%s\t%s\t%d\t%s\n",p->name,p->age,p->worktime,p->sex,p->marrige,p->grade,p->tired);
                 }
            }
         else if(choice==3)
         {        
                   printf("职工信息如下:\n姓名\t年龄\t工龄\t性别\t婚姻\t级别\t是否在职\n");
                    for(p=head;p!=NULL;p=p->next)
                    {
                        if(p->grade==grade)
                        printf("%s\t%d\t%d\t%s\t%s\t%d\t%s\n",p->name,p->age,p->worktime,p->sex,p->marrige,p->grade,p->tired);
                    }
        }
    }
    printf("按任意键继续....");
    getch();
}
printf("           \t\t您已退出查询系统\n\n");
}

STU *findByName(STU *head,char *name)
{
    STU *p,*result=NULL;
    for(p=head;p!=NULL;p=p->next)
        if(strcmp(p->name,name)==0)
        {
            result=p;
            break;
        }
return result;
}

STU *findByWorktime(STU *head,int worktime)
{
    STU *p,*result=NULL;
    for(p=head;p!=NULL;p=p->next)
        if(p->worktime==worktime)
        {
            result=p;
            break;
        }
return result;
}

STU *findByGrade(STU *head,int grade)
{
    STU *p,*result=NULL;
    for(p=head;p!=NULL;p=p->next)
        if(p->grade==grade)
        {
            result=p;
            break;
        }
        return result;
}

STU *insert(STU *head)
{
    STU *pnew,*pcur,*pbefore,*p;
    int choice;
    printf("输入职工信息:\n");
    for(;;)
    {
        //1.申请一个新节点并赋值
        pnew=(STU *)malloc(sizeof(STU));
        printf("职工信息如下:\n姓名\t年龄\t工龄\t性别\t婚姻\t级别\t是否在职\n");
        scanf("%s%d%d%s%s%d%s",pnew->name,&pnew->age,&pnew->worktime,pnew->sex,pnew->marrige,&pnew->grade,pnew->tired);
        pnew->next=NULL;
        //2.将新节点插入到链表
        //若链表为空,则直接插入;若链表不为空,则查找位置,然后插入
    if(head==NULL)
    {
        head=pnew;  
    }
    else
    {
        pcur=NULL;
        for(p=head;p!=NULL;pbefore=p,p=p->next)
            if(strcmp(p->name,pnew->name)==1)
            {
                pcur=p;
                break;
            }
            //查找之后,判断pcur是否为空,
            //若pcur为空,则pnew所指节点应插入到链表尾部 
        if(pcur==NULL)
        {
            pbefore->next=pnew; 
        }
        //若pcur非空,则pnew所指节点应插入到pcur之前,pbefore之后,此时,又分两种情况:
        //pcur指向的是首节点,或者pcur指向后续节点;
        else
        {
            if(pcur==head)
            {
                pnew->next=pcur;
                head=pnew;
            }
            else
            {
                pnew->next=pcur;
                pbefore->next=pnew;
            }
        }
    }
    printf("请选择:按1继续添加->按0结束添加\n");
    printf("choice=");
    scanf("%d",&choice);
    if(choice==0)
        {   
            printf("信息添加完毕!\n");
            break;
        }
    }
   return head;
}

STU *del(STU *head)
{
    STU *presult,*pbefore;
    char name[20];
    printf("要删除的职工信息:");
    scanf("%s",&name);
    presult=findByNumEx(head,name,&pbefore);
    if(presult!=NULL)
    {
        printf("找到了!职工信息如下:\n姓名\t年龄\t工龄\t性别\t婚姻\t级别\t是否在职\n");  
        printf("%s\t%d\t%d\t%s\t%s\t%d\t%s\n",presult->name,presult->age,presult->worktime,presult->sex,presult->marrige,presult->grade,presult->tired);    
        if(presult==head)
        {
            head=presult->next;
        }
        else
        {
            pbefore->next=presult->next;
        }
        printf("删除成功---> ");
    }
    else
        printf("无与此职工相关的信息\a\a\n");
    return head;
}

//函数说明:
//  在head所指向链表中,查找学号为num的节点
//  找到后,返回两个值:指向当前节点的指针presult,指向当前节点的前一节点的指针pbefore,
//  presult通过函数返回值返回(即return),pbefore通过输出型参数ppBefore返回
STU *findByNumEx(STU *head,char name[],STU **ppbefore)
{
    STU *p,*presult=NULL,*pbefore=NULL;
    for(p=head;p!=NULL;pbefore=p,p=p->next)
        if(strcmp(p->name,name)==0)
        {
            presult=p;
            break;
        }
    if(p==NULL)
    pbefore=NULL;
    *ppbefore=pbefore;
    return presult;
}

void update(STU *head)
{
    STU *presult;
    char name[20];
    printf("输入要修改员工姓名:\n");
    scanf("%s",name);
    presult=findByName(head,name);
    if(presult==NULL)
        printf("查无此人!无法修改!\a\n");
    else
    {
    printf("找到了!职工信息如下:\n姓名\t年龄\t工龄\t性别\t婚姻\t级别\t是否在职\n");  
    printf("%s\t%d\t%d\t%s\t%s\t%d\t%s\n",presult->name,presult->age,presult->worktime,presult->sex,presult->marrige,presult->grade,presult->tired);    
        printf("请输入修改信息:\n");
        printf("姓名\t年龄\t工龄\t性别\t婚姻\t级别\t是否在职\n");   
            scanf("%s%d%d%s%s%d%s",presult->name,&presult->age,&presult->worktime,presult->sex,presult->marrige,&presult->grade,presult->tired);
        printf("修改完毕---> ");
    }
}

void sort(STU *head)//按级别排序
{
    STU *pi,*pj,*pindex,*p;
    STU temp;
    int len=sizeof(STU)-sizeof(STU *);
    int i,j,n=0;
    for(p=head;p!=NULL;p=p->next)
        n++;
    for(pi=head,i=0;i<n-1;i++,pi=pi->next){
        pindex=pi;
        for(pj=pi->next,j=i+1;j<n;j++,pj=pj->next)
            if(pindex->grade> pj->grade)
                pindex=pj;
            memcpy(&temp,pi,len); 
        memcpy(pi,pindex,len); 
        memcpy(pindex,&temp,len); 
    }
    printf("排序完毕---> ");
}

void save_info(STU *head)
{
    char filename[20];
    FILE *fp;
    STU *p;
    printf("保存当前信息到文件的处理\n");
    printf("请输入文件名:");
    scanf("%s",filename);
    if((fp=fopen(filename,"w"))==NULL)
    {
        printf("无法打开文件\n");
        return;
    }
    fprintf(fp,"全部职工信息如下:\n姓名\t年龄\t工龄\t性别\t婚姻\t级别\t是否在职\n");
    for(p=head;p!=NULL;p=p->next)
    fprintf(fp,"%s\t%d\t%d\t%s\t%s\t%d\t%s\n",p->name,p->age,p->worktime,p->sex,p->marrige,p->grade,p->tired);
    fprintf(fp,"%d",0);
    fclose(fp);
    printf("保存完成!--->");
}

void copy()
{
    FILE *in,*out;
    char infile[40],ch;
    char outfile[40];
    printf("现在进入学生信息文件的备份\n");
    printf("源文件名:");
    scanf("%s",infile);
    printf("备份文件名:");
    scanf("%s",outfile);
    if((in=fopen(infile,"r"))==NULL)
    {
        printf("文件无法打开\n");
        exit(0);
    }
    if((out=fopen(outfile,"w"))==NULL)
    {
        printf("文件无法打开\n");
        exit(0);
    }
    ch=fgetc(in);
    while(ch!=EOF)
    {
        fputc(ch,out);
        ch=fgetc(in);
    }   
        fclose(in);
        fclose(out);
        printf("备份成功!\n");
}

STU *load_info()
{
    STU *head=NULL,*pnew,*pend;
    char filename[20];
    char a[20];
    FILE *fp;
    int i;
    printf("           \t\t文件加载职工信息,输入文件名:");
    scanf("%s",filename);
    if((fp=fopen(filename,"r"))==NULL)
    {
        printf("           \t\t加载失败!\n");
        exit(0);
    }
    for(i=0;i<8;i++)
        fscanf(fp,"%s",a);
    for(;;)
    {
        pnew=(STU *)malloc(sizeof(STU));
        fscanf(fp,"%s",&pnew->name);
            if(strcmp(pnew->name,"0")==0)
                break;
        fscanf(fp,"%d%d%s%s%d%s",&pnew->age,&pnew->worktime,&pnew->sex,&pnew->marrige,&pnew->grade,&pnew->tired);
        pnew->next=NULL;
            if(head==NULL)
        {
            head=pnew;
            pend=pnew;
        }
        else
        {
            pend->next=pnew;
            pend=pnew;
        }
    }
    fclose(fp);
    printf("           \t\t加载成功!\n");
    return head;
}

char *password()
{
    char password[100],c;
    char *result=NULL;
    int e,count;
    e=0;count=0;
    while((c=getch())!=13&&e<100)//13为回车
              { 
                     if(c==8&&e>0)//8为退格
                     {
                            password[e--]='\0';//删除最后一个,并且计数器减1
                            printf("\b \b");//退格
                     }
                     else
                     {
                            password[e++]=c;
                            printf("*");//覆盖*号,当输出空格覆盖前一个字符后,再一次前移,以便下一次输入
                     }
              }
             password[e]='\0';
             if(strcmp(password,"123456")==0)
                result=1;     
            return  result;
}

程序运行效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C语言实现学生信息管理系统(单链表)

    本文实例为大家分享了C语言实现学生信息管理系统的具体代码,供大家参考,具体内容如下 /*copyright(c)2016.烟台大学计算机学院 * All rights reserved, * 文件名称:text.Cpp * 作者:吴敬超 * 完成日期:2016年7月1日 * 版本号:codeblock * * 问题描述: 学生信息管理系统 * 输入描述: * 程序输出: 输出结果 */ #include <stdio.h> #include <stdlib.h> #include

  • C语言学生信息管理系统小项目

    本文为大家分享了C语言学生信息管理系统小项目,供大家参考,具体内容如下 /* 运行环境:我是在linux里面用gcc编译的,在windows里应该也能运行,用的一些文件库函数都是c标准库,没有用linux的系统调用(纠正一下:system("clear")这个系统调用是linux的,windows里面用system("cls") ) (1)问题描述 学生信息包括:学号,姓名,年龄,性别,出生年月,地址,电话,E-mail等.试设计一学生信息管理系统,使之能提供以下功

  • C语言版学生信息管理系统

    本文实例为大家分享了C语言版学生信息管理系统的具体代码,供大家参考,具体内容如下 一.题目分析 1.功能概述 1)查询学生信息 2)添加学生信息 3)修改学生信息 4)删除学生信息 5)刷新学生信息 6)保存学生信息 7)输出当前学生信息 2.题目要求: 1)使用结构体建立学生信息体制 2)实现七大基本功能 3)采用文件存储学生信息 二.算法构造 1.难点解析----对文件的操作 1.1文件读取 FILE * fp; if ((fp = fopen(filename, "r")) ==

  • C语言实现歌曲信息管理系统

    本文实例为大家分享了C语言实现歌曲信息管理系统的具体代码,供大家参考,具体内容如下 系统功能:该系统以菜单方式工作,歌曲信息包括:歌名.演唱者.作词.作曲.所属专辑.出版时间.出版公司.试设计一歌厅歌曲管理系统,使之能提供以下功能:歌曲信息录入.修改.插入.删除功能:歌曲排序浏览功能:按歌名查询.按演唱者查询等功能. 完整的实现代码如下: #include "stdio.h" #include "stdlib.h" #include "string.h&q

  • C语言单链表版学生信息管理系统

    本文实例为大家分享了C语言学生信息管理系统的具体代码,供大家参考,具体内容如下 代码: //以单链表作为存储结构,设计和实现课程成绩管理的完整程序. //程序包括如下功能. //1.建立学生成绩表,包含学生的学号.姓名和成绩. //2.可以显示所有学生成绩. //3.可以计算学生的总数. //4.可以按学号和序号查找学生. //5.可以在指定位置插入学生成绩数据. //6.可以删除指定位置的学生数据. //7.可以把学生成绩按从高到低的顺序排序. //作者: yinlinqvan //操作系统:

  • 学生信息管理系统C语言版

    C语言学生信息管理系统包括以下功能: 1.学生信息的整体注册 2.学生信息的修改 3.学生成绩信息的录入 4.学生信息的添加 5.恢复误删的学生信息 6.学生信息的删除 7.密码修改保存函数 8.学生信息的查询 9.密码修改函数 10.学生信息管理系统的菜单函数 #include "stdio.h" #include "malloc.h" #include "string.h" #include "stdlib.h" #inc

  • C语言职工信息管理系统源码

    本文实例为大家分享了C语言职工信息管理系统的具体代码,供大家参考,具体内容如下 #include <stdio.h> #include <stdlib.h> #include <string.h> #include <conio.h> struct worker { char ID[20];//工号 char name[20];//姓名 char sex[5];//性别 char born[20];//生日 char edu[20];//学历 char po

  • C语言数据结构之学生信息管理系统课程设计

    本文实例为大家分享了学生信息管理系统设计的具体代码,供大家参考,具体内容如下 建立一个动态链表,链表中每一结点包括:学号.姓名.性别.年龄.成绩.程序能实现以下功能: 建立链表      显示链表      查找链表中是否存在某个元素,并显示这个元素的所有信息,若没有这个元素则显示"无此记录!"的信息.      删除链表中指定学号的结点.      在链表中指定的位置插入一个新结点(学号不能和其他结点重复). 要求:程序运行中,先显示实现以上功能所构成的菜单,然后根据选项调用相应程序

  • C语言学生信息管理系统设计与实现

    本文实例为大家分享了C语言学生信息管理系统的具体代码,供大家参考,具体内容如下 #include"stdio.h" //标准的输入输出函数文件头部说明 #include"math.h" // 数学函数头部说明 #include"string.h" #include"stdlib.h" //通过该函数头部里的函数,改变控制台的背景和颜色 #include"windows.h" //头文件声明,下文用到了改变控

  • c语言实现的货物管理系统实例代码(增加删除 查找货物信息等功能)

    复制代码 代码如下: #include <stdio.h>#include <stdlib.h>#include <string.h>#include <conio.h>        /*屏幕操作函数库*/ /*主管权限数据格式化*/#define HEADER1_zg "-----------------------------货物管理系统(主管)--------------------------------\n"#define H

随机推荐