精华内容
下载资源
问答
  • 浙江工商大学计算机与信息工程学院 数据结构实验大作业报告 专 业 电 子 商 务 班 级 商 务1202 学 号 1212200206 姓 名 陈志伟 指导教师 韩建伟 2013 年 5 月 一问题分析 职工管理系统是一个工作单位不可缺少的管理...
  • 员工管理数据结 构员工管理系统 壹设计题目 [问题描述] 每个员工的信息包括编号姓名性别出生年月学历职务 电话住址等系统能够完成员工信息的查询更新插 入删除排序等功能 [基本要求] 1 排序按不同关键字对所有员工的...
  • 为某小型公司编写一个职工信息管理程序 该管理程序处理的对象:公司、部门、职工 总经理1位,部门若干,部门内设有部门经理1位、职工若干位等等
  • 6/10/2020 成 绩 成 绩 信计 一 12信计2013-2014 一 12 2013-2014 数 据 结 构 课 程 设 计 数 据 结 构 课 程 设 计
  • 数据结构员工信息管理系统,课程设计用,用MFC和C++实现
  • 数据结构职工管理系统

    千次阅读 2019-01-13 17:06:04
    #include <stdio.h> #include <stdlib.h> ...//建立包含职工号、姓名、部门、工资的结构体 { int no; /*职工号*/ char name[10]; /*姓名*/ i

    主要功能:存储职工的职工号、姓名、部门号、工资,实现职工号、部门号、工资的排序,删除单个职工的记录、删除全部职工的记录。

    #include <stdio.h> 
    #include <stdlib.h> 
    #include <string.h> 
    #include <malloc.h>
    struct Worker 
    //建立包含职工号、姓名、部门、工资的结构体 
    { 
    	int no; /*职工号*/ 
    	char name[10]; /*姓名*/ 
    	int depno;    /*部门*/
    	int salary; /*工资*/ 
    	
    }; 
    //typedef struct Worker *pworker; 
    
    struct LINK
    ///此为定义链表的结构体,结构名为LINK,结构成员为Worker和LINK 
    { 
    	Worker w; 
    	LINK *next; 
    }; 
    typedef struct LINK *PLINK; 
    
    /*程序结束时释放内存*/ 
    void release(PLINK p) 
    { 
    	PLINK q; 
    	while(NULL!=p->next) 
    	{ 
    		q=p; 
    		p=p->next; 
    		free(q); 
    	} 
    	free(p); 
    } 
    
    /*创建职工信息链表*/ 
    PLINK create() 
    { 
    	PLINK p=(PLINK)malloc(sizeof(struct LINK)); 
    	if(NULL!=p) 
    	{ 
    		p->next=NULL; 
    		return p; 
    	} 
    	printf("内存不足!\n"); 
    	return NULL; 
    }
    
     /*显示程序界面文字*/ 
    void message() 
    { 
    	system("cls");//清屏 
    	system("color 00a");//字的颜色 
    	
    	 
    	printf("                         --请输入:【1】  录入职工信息\n"); 
    	printf("                         --请输入:【2】  浏览职工信息\n"); 
    	printf("                         --请输入:【3】  按职工号排序\n"); 
    	printf("                         --请输入:【4】  按部门号排序\n");
    	printf("                         --请输入:【5】  按工资数排序\n"); 
    	printf("                         --请输入:【6】  删除指定职工号信息\n"); 
    	printf("                         --请输入:【7】  删除职工文件中的全部记录 \n"); 
    	printf("		         --请输入:【8】  清屏\n"); 
    	printf("                         --请输入:【-1】 退出\n"); 
    } 
    
    void SaveFile(PLINK p)	//将职工单链表数据存入数据文件
    {
    	PLINK q=p->next;
    	int n=0;
    	FILE *fp;
    	if ((fp=fopen("work.txt","wb"))==NULL)   //以只写(‘wb’)的方式打开名为‘emp.dat’的文件
    	{	
    		printf("  提示:不能创建文件work.txt\n");
    		return;
    	}
    	while (q!=NULL)
    	{
    		fwrite(&q->w,sizeof(Worker),1,fp);         //文件写接口
    		q=q->next;
    		n++;
    	}
    	fclose(fp);                               //关闭文件
    	release(p);				//释放职工单链表L
    	if (n>0)
    		printf("  提示:%d个职工记录写入work.txt文件\n",n);
    	else
    		printf("  提示:没有任何职工记录写入work.txt文件\n");
    }
    
    /*录入职工信息*/ 
    int add(PLINK p) 
    
    //采用头插法 
    { 
    	PLINK q=(PLINK)malloc(sizeof(struct LINK)); 
    	if(NULL==q) 
    	{ 
    		printf("录入失败提示:内存不足!\n"); 
    		return -1; 
    	} 
    	printf("请输入职工号(数字):"); 
    	scanf("%d",&q->w.no); 
    	PLINK h=p->next; 
    	while(h) 
    	{ 
    		if(h->w.no==q->w.no) 
    		{ 
    			free(q); 
    			printf("录入失败提示:此职工号已经存在!\n"); 
    			return -1; 
    		} 
    		h=h->next; 
    	} 
    
    	printf("请输入职工姓名(文字):"); 
    	scanf("%s",&q->w.name); 
    	printf("请输入职工部门号(数字):"); 
    	scanf("%d",&q->w.depno); 
    	printf("请输入职工工资数(数字):"); 
    	scanf("%d",&q->w.salary); 
     
    	q->next=p->next;                        //头插法
    	p->next=q; 
    	printf("录入成功!\n"); 
    	return -1; 
    } 
    void nopai(PLINK p){				//职工号排序
    	PLINK o,pre,q;
    	o=p->next->next;
    	p->next->next=NULL;
    	while(o!=NULL){
    	q=o->next;
    	pre=p;
    	while(pre->next!=NULL&&pre->next->w.no<o->w.no)
    		pre=pre->next;
    	o->next=pre->next;
    	pre->next=o;
    	o=q;
    	}
    }
    
    void depnopai(PLINK p){				//部门号排序
    	PLINK o,pre,q;
    	o=p->next->next;
    	p->next->next=NULL;
    	while(o!=NULL){
    	q=o->next;
    	pre=p;
    	while(pre->next!=NULL&&pre->next->w.depno<o->w.depno)
    		pre=pre->next;
    	o->next=pre->next;
    	pre->next=o;
    	o=q;
    	}
    }
    
    void salarypai(PLINK p)
    //冒泡排序 
    {				//工资排序
    	PLINK o,pre,q;
    	o=p->next->next;
    	p->next->next=NULL;
    	while(o!=NULL){
    	q=o->next;
    	pre=p;
    	while(pre->next!=NULL&&pre->next->w.salary<o->w.salary)
    		pre=pre->next;
    	o->next=pre->next;
    	pre->next=o;
    	o=q;
    	}
    }
    /*浏览职工信息*/
    void show(PLINK p) 
    { 
    	message(); 
    	printf("浏览职工信息\n"); 
    	printf("职工号\t姓名\t部门号\t工资\t\n"); 
    	while(NULL!=p->next) 
    	{ 
    		printf("%d\t%s\t%d\t%d\t\n", 
    		p->next->w.no,p->next->w.name,p->next->w.depno,p->next->w.salary);
    	
    		p=p->next; 
    	} 
    	printf("显示完毕!\n"); 
    } 
    /*按职工号删除职工信息*/ 
    int del(PLINK p,int no) 
    { 
    	message(); 
    	printf("按职工号删除职工信息\n"); 
    	while(NULL!=p->next) 
    	{ 
    		if(p->next->w.no==no) 
    		{ 
    			PLINK q=p->next; 
    			p->next=p->next->next; 
    			free(q);                    //释放结点
    			printf("删除成功!\n"); 
    			return 1; 
    		} 
    		p=p->next; 
    	} 
    	printf("没有你输入的职工号!\n"); 
    	return -1; 
    }
    void dell(PLINK p){			//删除全部员工记录
    	while(NULL!=p->next)   
    	{ 
    		
    		
    			PLINK q=p->next; 
    			p->next=p->next->next; 
    			free(q);                    //释放结点
    			
    		} 
    		p=p->next; 
    }
    
    
    int main() 
    { 
    	int cmd=0;/*命令号*/ 
    	int no; 
    	char name[4]; 
    	PLINK pworker; 
    	if(!(pworker=create())) 
    	{ 
    		exit(0);/*如果创建职工信息链表表头失败则结束程序*/ 
    	} 
    	while(cmd!=-1) 
    	{ 
    		switch(cmd) 
    		{ 
    			case 0: 
    				message(); 
    			break; 
    			case 1: 
    				add(pworker); 
    			break; 
    			case 2: 
    				show(pworker); 
    			break; 
    			case 3: 
    				nopai(pworker);
    				show(pworker);
    				printf("按职工号排列成功!\n");
    			break; 
    			case 4: 
    				depnopai(pworker);
    				show(pworker);
    				printf("按部门号排列成功!\n"); 
    			break;
    			case 5: 
    				salarypai(pworker);
    				show(pworker);
    				printf("按工资排列成功!\n"); 
    				break; 
    			case 6: 
    				printf("请输入要删除的职工号:"); 
    				scanf("%d",&no); 
    				del(pworker,no); 
    				show(pworker);
    				printf("删除成功!\n"); 
    			break; 
    			case 7: 
    			
    				dell(pworker);
    				show(pworker);
    				printf("已经删除全部记录!"); 
    				break; 
    
    			case 8: 
    				default: 
    				message(); 
    			} 
    		printf("请输入操作命令数字:\n"); 
    		scanf("%d",&cmd);/*接收命令*/ 
    		} 
     
        release(pworker);
    	return 0; 
    } 
    
    展开全文
  • 仲恺农业工程学院 仲 恺 农 业 工 程 学 院 课 程 设 计 报 告 题目员工管理系统 课程名称 数据结构与算法 信息科学与技术学院 院 系 专业班级 学 号 名 姓 3 仲恺农业工程学院 目 录 综合设计题目. 5 一问题所需要...
  • 简单的职工管理系统数据结构

    热门讨论 2010-03-20 19:18:03
    简单的职工管理系统,内含源代码和文档 简单的职工管理系统主要实现以下功能: (1) 新增一名职工:将新增职工对象按姓名以字典方式职工管理文件中。 (2) 删除一名职工:从职工管理文件中删除一名职工对象。 ...
  • 让你轻松得到的小系统,我编了12小时!!和大家一起分享
  • 员工管理系统数据结构大学课程实训作业。C语言版本
  • 简单的职工管理系统主要实现以下功能: (1) 新增一名职工:将新增职工对象按姓名以字典方式职工管理文件中。 (2) 删除一名职工:从职工管理文件中删除一名职工对象。 (3) 查询:从职工管理文件中查询符合某些...
  •  对单位的职工进行管理,包括插入、删除、查找、排序等功能。 1.2要求  职工对象包括工号、姓名、性别、出生年月、工作年月、学历、职务、住址、电话等信息。 (1)新增一名职工:将新增职工对象按姓名以字典方式...
  • 编写一个简单的人事管理系统,要求功能如下: 用链表存储、文件输入、输出。 具有建立、插入、删除、查询和打印功能。 管理的人员有: 本科生:姓名、性别、年龄、身份证号码、高考总分 脱产研究生:姓名、性别...
  • 运动会分数统计系统(数据结构课程设计),已经调试过了.
  • 数据结构课设 员工管理系统 C++源码 需要的拿去
  • 数据结构通讯录管 理系统课程设计报 告 课程设计大作业报告 课程名称 数据结构 设计题目通讯录信息管理系统 院系信息技术学院 班级12级计算机2班 设计者 * 学号 11010214 指导教师: SSSSSS 设计时间.12.28 .12.31 ...
  • 数据结构课设--简单的职工管理系统
  • 设计一个职工管理系统。功能:登录,职工信息的录入,按照工号查找职工信息,插入新职工信息,删除离职员工信息,修改职工年龄,修改职工工资,将职工按照工号的顺序输出,将员工按照年龄的顺序输出,将职工按照工资...
  • 数据结构课程设计,一个简单的基于二叉排序树的员工信息管理系统
  • 系统能够完成员工信息的查询、更新、插入、删除、排序等功能。 要求:  (1) 排序:按不同关键字,对所有员工的信息进行排序。  (2) 查询:按特定条件查找员工。  (3) 更新:按编号对某个员工的某项信息进行...
  • 职工工资管理系统源代码,C语言实训,包含增删查改,排序,实现对文件的操作,含栈、单链、数组管理员工信息,及时整理员工工资信息,可以经修改后直接用
  • 包括职工号,姓名,职务,单位,薪水。 还有按条件查询以及排序
  • 6/10/2020 仲恺农业工程学院 仲恺农业工程学院 仲 恺 农 业 工 程 学 院 仲 恺 农 业 工 程 学 院 课 程 设 计 报 告 课 程 设 计 报 告 题 目员工管理系统 题 目员工管理系统 数据结构与算法 课程名称 数据结构与...
  • 职工工资管理系统

    2018-07-12 10:30:24
    Java实现的职工工资管理系统,包含用户登录界面,工资管理
  • 该程序用c++语言编写,主要用到数据结构中的二叉树,做的职工管理系统,主要用于其创建,查找,删除,添加等
  • 系统能够完成员工信息的查询、更新、插入、删除、排序等功能。 (1) 排序:按不同关键字,对所有员工的信息进行排序。 (2) 查询:按特定条件查找员工。 (3) 更新:按编号对某个员工的某项信息进行修改。 ...
  • 数据结构课程设计报告-职工信息管理系统

    万次阅读 多人点赞 2016-02-24 13:34:39
    数据结构”课程设计报告 职工信息管理系统 课程设计任务与要求: [问题描述] 每个员工的信息包括:编号、姓名、性别、出生年月、学历、职务、电话、住址等。系统能够完成员工信息的查询、更新、插入、删除、排序等...

     

    “数据结构”课程设计报告

     

     

     

    系 (院):           信息工程学院              

    设计题目:           员工管理系统              

    专业班级:          计算机科学与技术1401B     

    小组成员:     杜康辉 1434110115              

    小组成员:     吴孝乐 1434110147              

    小组成员:     张广然 1434110133              

    指导教师:              汪洋                  

    完成时间:       2015~2016学年第一学期        

     

     

     

    目录

    第一部分 课程设计目的 1

    第二部分 课程设计任务与要求 1

    一、问题描述 1

    二、基本要求 1

    三、测试数据 1

    四、实现提示 1

    第三部分 程序设计流程  2

    一、需求分析 2

    二、概要设计 2

    三、详细设计 3

    四、设计与调试分析 9

    五、用户手册 9

    六、测试成果 10

    七、附录(原程序清单) 14

    八、课程设计心得 30

    第四部分 参考文献 31


    ² 课程设计目的

    1、能够灵活地应用所学数据结构知识,根据加工数据对象的特征,选择适当的数据结构、存贮结构及相应算法,独立完成问题分析,结合数据结构理论知识,编写程序求解指定问题。

    2. 初步掌握各种算法在时间和空间的分析技巧;初步掌握软件开发过程的问题分析、系统设计、程序编码、测试等基本方法和技能;

    3. 能够进行算法设计和程序设计,并且使所设计的程序结构清楚,正确易读,并上机调试通过;提高综合运用所学的理论知识和方法独立分析和解决问题的能力。

    4.用系统的观点和软件开发一般规范进行软件开发,巩固、深化学生的理论知识,提高编程水平,并在此过程中培养他们严谨的科学态度和良好的工作作风。

    5. 培养较强的实习和实践能力;较强的分析问题和解决问题的能力。

    ² 课程设计任务与要求:

    [问题描述]

    每个员工的信息包括:编号、姓名、性别、出生年月、学历、职务、电话、住址等。系统能够完成员工信息的查询、更新、插入、删除、排序等功能。

    [基本要求]

    (1) 排序:按不同关键字,对所有员工的信息进行排序。

    (2) 查询:按特定条件查找员工。

    (3) 更新:按编号对某个员工的某项信息进行修改。

    (4) 插入:加入新员工的信息。

    (5) 删除:按编号删除已离职的员工的信息。

     

    [测试数据]

      每个员工的信息:编号、姓名、性别、出生年月、学历、职务、电话、住址等。

    [实现提示]

    通过相关操作会使输入显示在屏幕上。

    一 需求分析

    1.设计“职工信息管理系统”,使其实现对职工信息的建立、查询、删除、修改和遍历操作。

    2.数据包括:职工号、姓名、性别、年龄、学历、工资、住址、电话等。

    3.能够对其中的职工信息进行修改和删除。

    4.能够实现对所有职工信息的遍历。

    5.能够实现查找功能:

    ①完成按职工的职工号查询职工的相关信息,并显示。

    ②完成按职工的学历查询职工的相关信息,并显示。    

    ③完成按职工的电话号码查询职工的相关信息,并显示。

     

    二 概要设计

    1.用结构体指针数组来实现。

    2.实现对职工基本信息的录入。

    3.实现对职工基本信息的浏览。

    4.实现对职工基本信息的查找。

    5.实现对职工基本信息的删除。

    6.实现对职工基本信息的添加。

    7.实现对职工基本信息的修改。

    系统功能模块结构图

     

     

     

    /*定义存储单元基本信息的结构*/

    struct employee           //定义结构体employee

    {

     int num;                

    char name[10];          //职工姓名

    char sex;               //职工性别

    char xueli[30];          //学历

    int wage;              //年龄

    char addr[30];         //住址

    long int tel;            //电话

    }em[100]; 

    三 详细设计

     


     

    四 设计与调试分析

    调试过程中会遇到输入超出范围等容易因为手误犯的错误,这一点一定要注意,编写程序之前,首先要对如何设计程序有一个清晰的思路,清楚怎么去设计,然后系统分析与系统设计,最后是代码设计与调试。这些都是编写课程设计的步骤,同时,还得注意要把程序编写得易懂,让界面清楚。

    设计过程中,我们根据以往学过的数据结构的概念、理论和方法,设计程序的基本步骤,来完成这个应用,同时也加深了我们对数据结构的掌握程度。

    经过本次设计,我们的程序设计能力得到了很大的提高,但相对于那些高手来说,还有很大差距,仍需继续努力。而且,我还懂得要增强团队合作,要有合作精神,这样才会有意想不到的结果。

     

    五 用户手册

    提示操作:

     

    分析:提示开始输入数据的操作!

    1.录入职工信息操作:

     

    分析:录入职工信息的数据!

    2.浏览职工信息操作:

     

    分析:浏览职工信息

    3.查询职工信息操作:

     

    分析:输入要查询的职工号,学历,电话号码!

    4.删除职工信息操作:

     

    分析:输入要删除的职工姓名!

    5.添加职工信息操作:

     

     

    分析:输入要添加的职工信息!

    6.修改职工信息操作:

    分析:输入要修改的职工的姓名!

     

    注:任意输入一个数据后进入系统,然后根据系统提示操作即可。

    六 测试成果

     

    七 附录(源程序清单)

    //******************************************************

    //*  程 序 名职工信息管理系统                                  

    //*  作    者杜康辉、吴孝乐、张广然

    //*  编制时间: 201612日                                  

    //*  主要功能职工信息管理                                  

    //******************************************************

    #include <stdio.h>

    #include <windows.h>

    #include <time.h>

    #include <string.h>

    #define N 100

    struct employee

    {

        int num;

    char name[10];

    char sex;  

    int age;

    char xueli[30];

        int wage;

    char addr[30];

    long int tel;

    }em[100];        /*定义一个结构体*/

    void menu();

    void input();

    void save(int);

    void display();

    void del();

    void add();

    void search();

    void search_num();

    void search_xueli();

    void search_tel();

    void modify();  /*定义各函数*/

     

    void menu()   /*菜单函数*/

    {

    //printf("              ☆☆☆计算机科学与技术☆☆☆\n");

        //printf("\n");

        //printf("                                   1401B班 ∮\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"); 

    }

    int main()

    {   

    menu();  /*调用菜单函数*/

    int n,flag;

    char a;

    do

    {

    printf("请选择你需要操作的步骤(1--7):\n");

    scanf("%d",&n);

    if(n>=1&&n<=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;i<m;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("请输入性别(f--女  m--):  ");

    scanf("%c",&em[i].sex);

    printf("请输入年龄:  ");

    scanf("%d",&em[i].age);

    printf("请输入学历:  ");

    scanf("%s",em[i].xueli);

    printf("请输入工资:  ");

    scanf("%d",&em[i].wage);

    printf("请输入住址:  ");

    scanf("%s",em[i].addr);

            printf("请输入电话:  ");

    scanf("%d",&em[i].tel);

    printf("\n");

    }

    printf("\n创建完毕!\n");

    save(m);

    }

    void save(int m)  /*保存文件函数*/

    {

    int i;

    FILE*fp;

    if ((fp=fopen("employee.txt","w"))==NULL)  /*创建文件并判断是否能打开*/

    {

    printf ("cannot open file\n");

    exit(0);

    }

    for (i=0;i<m;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.txt","r"))==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;i<m;i++) /*m为输入部分的职工人数*/

    printf("\n  %d\t%s\t%c\t%d\t%s\t%d\t%s\t%ld\n",em[i].num,em[i].name,em[i].sex,em[i].age,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;flag&&i<m;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%c\t%d\t%s\t%d\t%s\t%ld\n",em[i].num,em[i].name,em[i].sex,em[i].age,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;j<m-1;j++)

    {

    strcpy(em[j].name,em[j+1].name);

    em[j].num=em[j+1].num;

    em[j].sex=em[j+1].sex;

    em[j].age=em[j+1].age;

    strcpy(em[j].xueli,em[j+1].xueli);

    em[j].wage=em[j+1].wage;  

    strcpy(em[j].addr,em[j+1].addr);

    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("employee.txt","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("请输入性别(f--女  m--):  ");

    scanf("%c",&em[i].sex);

            printf("请输入年龄:  ");

    scanf("%d",&em[i].age);

    printf("请输入学历:  ");

    scanf("%s",em[i].xueli);

    printf("请输入工资:  ");

    scanf("%d",&em[i].wage);

    printf("请输入住址:  ");

    scanf("%s",em[i].addr);

            printf("请输入电话:  ");

    scanf("%d",&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>=1&&t<=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;i<m;i++)

    if(num==em[i].num)

    {  

    printf("\n已找到此人,其记录为:\n");

    printf("\n职工号\t\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话   \n");

    printf("\n%d\t%s\t%c\t%d\t%s\t%d\t%s\t%ld\n",em[i].num,em[i].name,em[i].sex,em[i].age,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;i<m;i++)

    if(strcmp(em[i].xueli,xueli)==0)

    {

    printf("\n已找到,其记录为:\n");

    printf("\n职工号\t\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话   \n");

    printf("\n%d\t%s\t%c\t%d\t%s\t%d\t%s\t%ld\n",em[i].num,em[i].name,em[i].sex,em[i].age,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()

    {

    long int tel;

    int i, t;

    int m=load();

    printf("请输入要查找的电话号码:\n");

    scanf("%ld",&tel);

    for(i=0;i<m;i++)

    if(tel==em[i].tel)

    {  

    printf("\n已找到此人,其记录为:\n");

    printf("\n职工号\t\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话   \n");

    printf("\n%d\t%s\t%c\t%d\t%s\t%d\t%s\t%ld\n",em[i].num,em[i].name,em[i].sex,em[i].age,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;  

    int age;

    char xueli[30];

        int wage;

    char addr[30];

        long int tel;

        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;flag&&i<m;i++)

    {

    if(strcmp(em[i].name,name)==0)

    {

    printf("\n已找到此人,原始记录为:\n");

                printf("\n职工号\t\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话   \n");

    printf("\n%d\t%s\t%c\t%d\t%s\t%d\t%s\t%ld\n",em[i].num,em[i].name,em[i].sex,em[i].age,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(c>8||c<1)  

    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("性别改为: "); getchar();scanf("%c",&sex);

        em[i-1].sex=sex; break;

    case 4:printf("年龄改为: "); scanf("%d",&age);

    em[i-1].age=age; 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("%ld",&tel); 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语言)

    千次阅读 多人点赞 2018-04-26 22:13:55
    1、添加员工模块:输入员工的姓名、年龄、职位、工龄以,通过自己定义的void add()函数来实现。将录入的信息写入到“data.dat”中。2、删除员工模块:删除需要删除的员工的所有信息,通过自己定义的void del( )...

    1、添加员工模块:输入员工的姓名、年龄、职位、工龄以,通过自己定义的void  add()函数来实现。将录入的信息写入到“data.dat”中。

    2、删除员工模块:删除需要删除的员工的所有信息,通过自己定义的void del( )函数来实现。先通过查找找到需要删除的信息,将文件中除要删除的信息之外全部读入内存,删除原文件,将创建一个同名文件。

    3、修改模块:可以修改该员工的部分信息,通过自己定义的void change()。根据选择修改具体部分。

    4、查询员工信息模块:可以按员工职务来查询员工的相关信息,通过自己定义的void search( )函数来实现。根据名字查询。

    5、员工信息排序模块:可以按照规定要求对员工信息排序,通过自己定义的void sort()函数来实现。分为按工龄和按专业降序排列,排序后将写入文件。

    6、员工信息输出模块:可以输出所有员工的信息,通过自己定义的void  display()函数实现。

    #include<stdio.h>
    #include<stdlib.h>
    #include<windows.h>
    #include<string.h>
    #define len sizeof(worker)
    typedef struct
    {
    	char name[20];//姓名
    	char sex;
    	int age;//年龄
    	int work_age;//工龄
    	char duty[20];
    	char education[20];
    	char address[40];
    	char phone[20];
    } worker;
    
    static int total;
    void add()    //添加
    {
    	FILE *fp;
    	worker b,b1;
    	fp=fopen("data.dat","ab+");
    	printf(" \n请输入职工姓名:   ");
    	scanf("%s",&b.name);
    	fflush(stdin);
    	printf(" \n请输入职工性别(f或m):    ");
    	scanf("%c",&b.sex);
    	while((b.sex!='f'&&b.sex!='m')||(b.sex!='m'&&b.sex!='f'))
    		{
    			fflush(stdin);
    			printf(" \n输入有误,请重新输入员工性别(f或m)注意f 或 m :    ");
    			scanf("%c",&b.sex);
    		}
    	printf(" \n请输入职工的年龄:   ");
    	scanf("%ld",&b.age);
    
    	printf(" \n请输入职工的工龄:   ");
    	scanf("%ld",&b.work_age);
    	printf(" \n请输入职工的职务 :   ");
    	scanf("%s",b.duty);
    	printf(" \n 请输入职工的学历(博士、硕士、本科、大专、高中、初中及以下)  : ");
    	scanf("%s",b.education);
    	printf(" \n请输入职工的居住地址 :   ");
    	scanf("%s",b.address);
    	printf(" \n请输入职工的电话:   ");
    	scanf("%s",b.phone);
    	fseek(fp,0,SEEK_SET);
    	while (fread(&b1,len,1,fp))
    		{
    			if((strcmp(b.name,b1.name)==0)&&(strcmp(b.address,b1.address)==0))
    				{
    					fclose(fp);
    					printf("\n信息库中已有同的信息,无法加入");
    					Sleep(2000);
    					system("cls");
    					return;
    				}
    		}
    	fseek(fp,0,SEEK_END);
    	fwrite(&b,len,1,fp);
    	fclose(fp);
    	printf("\t\t\t 添加成功!\n");
    	system("pause");
    
    }
    int record()
    {
    	worker b;
    	FILE *fp;
    	int i = -1;
    	if((fp=fopen("data.dat","rb+"))==NULL)
    		{
    			printf("文件打开错误");
    			exit(0);
    		}
    	fseek(fp,0,SEEK_SET);
    	while(!feof(fp))
    		{
    			i++;
    			fread(&b,len,1,fp);
    		}
    	return  i;
    }
    void display()
    {
    	if(record()==0)
    		{
    			printf("文件没有信息,去添加吧");
    		     system("pause");
    		}
    	else
    		{
    			worker sta;
    			FILE *fp;
    			fp=fopen("data.dat","rb");
    			fseek(fp,0,SEEK_SET);
    			fread(&sta,len,1,fp);
    			printf("姓名    性别  年龄   工龄    学历   职务   地址              电话\n");
    			printf("-----------------------------------------------------------------------------\n");
    			while(!feof(fp))
    				{
    					printf("%-10s %-4c %-4ld %-4ld   %-6s %-6s %-20s%-s\n",
    					       sta.name,sta.sex,sta.age, sta.work_age,sta.education,sta.duty,
    					       sta.address,sta.phone);
    					fread(&sta,len,1,fp);
    				}
    			system("pause");
    			fclose(fp);
    		}
    }
    void del()
    
    {
    	worker b,b1;
    	int flag=0,i=0;   //flag用于判断职工是否存在
    	total= record();
    	worker temp[total];
    	FILE *fp,*fp1;
    	char a[20];
    	if ((fp=fopen("data.dat","rb+"))==NULL)
    
    		{
    			printf("打开文件错误!!!\n");
    			Sleep(1000);
    			exit(1);
    		}
    	printf("\n请输入职工名字:");
    	scanf("%s",a);
    	system("cls");
    	fseek(fp,0,SEEK_SET);
    	while (fread(&b,len,1,fp))   //遍历文件所有结构体
    		{
    			if(!strcmp(a,b.name))
    				flag=1;           //判断有无此职工
    		}
    
    	if(flag==0)   //没有此职工退出函数
    
    		{
    			printf("\n\t\t\t没这人");
    			Sleep(2000);
    			system("cls");
    			return;
    		}
    
    	fseek(fp,0,SEEK_SET);
    	while((!feof(fp))&&(i<total))
    		{
    			fread(&b,len,1,fp);   //将除了要删除的信息之外的所有信息保存进结构体 book temp[total],写进内存
    			if (strcmp(a,b.name))
    				{
    					temp[i]=b;
    					i=i+1;
    				}
    		}
    	fclose(fp);
    	fp1=fopen("data.dat","wb");
    	fclose(fp1);
    	fp1=fopen("data.dat","ab");   //以覆盖原有的文件信息 的方式建立同名文件
    	for(i=0; i<total-1; i++)      //将 除了要删除的信息之外的所有信息保存进的结构体 book temp[total]赋值给b1,写入文件
    		{
    			b1=temp[i];
    			fseek(fp1,0,SEEK_END);
    			fwrite(&b1,len,1,fp1);
    		}
    	fclose(fp1);
    }
    void change()                        //修改职工信息
    
    {
    	int flag = 0;
    	worker b,b1;
    	FILE *fp;
    	char a[20];
    	if ((fp=fopen("data.dat","rb+"))==NULL)
    		{
    			printf("打开文件错误!!!\n");
    			Sleep(1000);
    			exit(1);
    		}
    	printf("请输入要修改信息的职工的姓名  :");
    	scanf("%s",a);
    	system("cls");
    	fseek(fp,0,SEEK_SET);
    	while (fread(&b,len,1,fp))             //遍历文件所有结构体
    		{
    			if (!strcmp(b.name,a))
    
    				{
    					printf("            【1】 修改姓名               【2】修改学性别\n");
    					printf("            【3】 修改年龄               【4】修改职务\n");
    					printf("            【5】 修改学历               【6】修改居住地址\n");
    					printf("            【7】 修改电话                            \n");
    					printf("请输入以上数字,选择相应的功能: ");
    					int  choice;
    					scanf("%d",&choice);
    					fflush(stdin);
    					switch(choice)
    						{
    							case 1 :
    							{
    								printf(" \n请输入职工姓名:   ");
    								scanf("%s",&b.name);
    								break;
    							}
    
    							case 2 :
    							{
    								printf(" \n请输入职工性别(f或m):    ");
    								scanf("%c",&b.sex);
    								break;
    							}
    							case 3 :
    							{
    								printf(" \n请输入职工的年龄:   ");
    								scanf("%ld",&b.age);
    								break;
    							}
    							case 4 :
    							{
    								printf(" \n请输入职工的职务 :   ");
    								scanf("%s",b.duty);
    								break;
    							}
    							case 5 :
    							{
    								printf(" \n 请输入职工的学历(博士、硕士、本科、大专、高中、初中及以下)  : ");
    								scanf("%s",b.education);
    								break;
    							}
    							case 6 :
    							{
    								printf(" \n请输入职工的居住地址 :   ");
    								scanf("%s",b.address);
    								break;
    							}
    							case 7 :
    							{
    								printf(" \n请输入职工的电话:   ");
    								scanf("%s",b.phone);
    								break;
    							}
    							default :
    								printf("\n输入错误");
    								system("pause");
    								break;
    						}
    					if(flag!=1)
    						{
    							fseek(fp,-len,SEEK_CUR);   /*位置指针移动到该数据块首位*/
    							fwrite(&b,len,1,fp);
    							printf("\n        修改成功!!!");
    							system("pause");
    							fclose(fp);
    							if (feof(fp))
    
    								{
    									printf("没有这个职工信息\n");
    									system("pause");
    
    								}
    						}
    				}
    		}
    }
    void search()                     //查询
    {
    	worker b;
    	int flag = 0;
    	char ch,a[20];
    	char name[20];
    	FILE *fp;
    	fp=fopen("data.dat","rb");
    	fseek(fp,0,SEEK_SET);
    	ch=fgetc(fp);
    	if((fp=fopen("data.dat","r"))==NULL)
    		{
    			printf("\t\t\t错误,请先添加!\n");
    			return ;
    		}
    	else if(ch==EOF)
    		{
    			printf("\t\t\t没信息!");
    			return;
    
    		}
    	else
    		{
    			printf("请输入查询信息的职工的姓名  :");
    			scanf("%s",a);
    			fseek(fp,0,SEEK_SET);
    			while (fread(&b,len,1,fp))             //遍历文件所有结构体
    				{
    					if (!strcmp(b.name,a))
    						{
    							printf("姓名    性别   年龄 工龄 学历   职务   地址              电话\n");
    							printf("-----------------------------------------------------------------------------\n");
    							printf("%-10s %-4c %-4ld %-4ld   %-6s %-6s %-20s%-s\n",
    							       b.name,b.sex,b.age, b.work_age,b.education,b.duty,
    							       b.address,b.phone);
    							flag = 1;
    							system("pause");
    						}
    				}
    			if (flag = 0)
    
    				{
    					printf("没有这个职工信息\n");
    					system("pause");
    				}
    		}
    }
    void work_age(int n)
    {
    	total = n;
    	int i=0,j;
    	char ch;
    	worker b,temp;
    	worker a[total];
    	FILE *fp;
    	fp=fopen("data.dat","rb+");
    	fseek(fp,0,SEEK_SET);
    	ch=fgetc(fp);
    	if(fp==NULL)
    		{
    			printf("\t\t\t错误,请先添加!\n");
    			return ;
    		}
    	else if(ch==EOF)
    		{
    			printf("\t\t\t文件没有信息!");
    			return;
    
    		}
    	else
    		{
    			fseek(fp,0,SEEK_SET);
    			while (fread(&b,len,1,fp))
    				{
    					a[i] = b;
    					i++;
    				}
    			for(i=1; i<total; i++)
    				{
    					temp= a[i];
    					j=i-1;
    					while(j>=0&&temp.work_age>a[j].work_age)
    						{
    							a[j+1] = a[j];
    							j--;
    						}
    					a[j+1]=temp;
    				}
    
    			fseek(fp,0,SEEK_SET);
    			for(i=0; i<total; i++)
    				fwrite(&a[i],len,1,fp);
    			fclose(fp);
    			display();
    		}
    }
    void education(int n)
    {
    	int i=0;
    	total = n;
    	char ch;
    	worker b,temp;
    	worker a[total];
    	FILE *fp;
    	fp=fopen("data.dat","rb+");
    	fseek(fp,0,SEEK_SET);
    	ch=fgetc(fp);
    	if(fp==NULL)
    		{
    			printf("\t\t\t错误,\n");
    			return ;
    		}
    	else if(ch==EOF)
    		{
    			printf("\t\t\t文件没有信息!");
    			return;
    		}
    	else
    		{
    			fseek(fp,0,SEEK_SET);
    			while (fread(&b,len,1,fp))
    				{
    					if(strcmp(b.education,"博士")==0)
    						{
    							a[i]=b;
    							i++;
    						}
    				}
    			fseek(fp,0,SEEK_SET);
    			while (fread(&b,len,1,fp))
    				{
    					if(strcmp(b.education,"硕士")==0)
    						{
    							a[i]=b;
    							i++;
    						}
    				}
    			fseek(fp,0,SEEK_SET);
    			while (fread(&b,len,1,fp))
    				{
    					if(strcmp(b.education,"硕士")==0)
    						{
    							a[i]=b;
    							i++;
    						}
    				}
    			fseek(fp,0,SEEK_SET);
    			while (fread(&b,len,1,fp))
    				{
    					if(strcmp(b.education,"本科")==0)
    						{
    							a[i]=b;
    							i++;
    						}
    				}
    			fseek(fp,0,SEEK_SET);
    			while (fread(&b,len,1,fp))
    				{
    					if(strcmp(b.education,"大专")==0)
    						{
    							a[i]=b;
    							i++;
    						}
    				}
    			fseek(fp,0,SEEK_SET);
    			while (fread(&b,len,1,fp))
    				{
    					if(strcmp(b.education,"初中及以下")==0)
    						{
    							a[i]=b;
    							i++;
    						}
    				}
    			for(i=0; i<total; i++)
    				{
    					printf("%10s",a[i].name);
    				}
    			printf("   \n");
    			fseek(fp,0,SEEK_SET);
    			for(i=0; i<total; i++)
    				fwrite(&a[i],len,1,fp);
    			fclose(fp);
    			display();
    		}
    }
    void sort()
    {
    	int j;
    	getchar();                         /*接收回车*/
    	j=record();
    	printf("            【1】 按工龄降排序               【2】按学历降排序\n");
    	printf("请输入以上数字,选择相应的功能: ");
    	switch (getchar())
    		{
    			case '1':
    				work_age(j);
    				break;
    			case '2':
    				education(j);
    				break;
    		}
    	getchar();                                /*接收回车*/
    	system("cls");
    	printf("            【1】 回到主界面               【2】退出系统\n");
    	printf("请输入以上数字,选择相应的功能: ");
    	switch(getchar())
    		{
    			case '1':
    				getchar();
    				system("cls");
    				break;
    			default:
    				exit(1);
    		}
    }
    
    
    int main()
    {
    	int flag=1;
    	while(flag)
    		{
    			fflush(stdin);
    			system("cls");             /*清屏*/
    			printf("                         欢迎登陆职工信息管理系统!\n");
    			printf("            【1】 输入职工信息            【2】 输出职工信息\n");
    			printf("            【3】 信息查询排序            【4】 删除职工信息\n");
    			printf("            【5】 修改职工信息            【6】 查询职工信息\n");
    			printf("请输入以上数字,选择相应的功能: ");
    			switch (getchar())
    				{
    					case '1':
    						add();
    						break;        /*调用输入信息的函数*/
    					case '2':
    						display();
    						break;       /*调用输出信息的函数*/
    					case '3':
    						sort();
    						break;       /*调用排序的函数*/
    					case '4':
    						del();
    						break;         /*调用删除职工信息函数*/
    					case '5':
    						change();
    						break;     /*调用修改职工信息的函数*/
    					case '6':
    						search();
    						break;       //查询员工信息
    					default:
    						flag=0;
    						break;       /*跳出循环体,结束程序*/
    				}
    		}
    	return 0;
    }
    
    
    
    
    
    

    展开全文
  • 6/10/2020 成 绩 成 绩 信计 一 12信计2013-2014 一 12 2013-2014 数 据 结 构 课 程 设 计 数 据 结 构 课 程 设 计
  • 数据结构课程设计,用链表实现的通讯录管理系统。 可以方便查询多个班级每一个同学的手机号、电子邮箱,及家庭住址等信息。 本系统用线性链表实现多个班级的同学通讯信息的管理,实现了数据文件的保存与读取功能。...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 80,390
精华内容 32,156
关键字:

职工管理系统数据结构

数据结构 订阅