C語言職工管理系統(tǒng)設(shè)計(jì)
本文實(shí)例為大家分享了C語言職工管理系統(tǒng)設(shè)計(jì)代碼,供大家參考,具體內(nèi)容如下
代碼如下:
#include<stdio.h>
#include<stdlib.h>
#include <string.h>
struct Worker
{
int id;//工號(hào)
char name[16];//姓名
char sex[8];//性別
int age;//年齡
char edu_exp[32];//學(xué)歷
int wage;//工資
char adress[32];//地址
char phong[16];//電話
Worker* next;
};
//創(chuàng)建表頭
Worker m_head = { 0 };
//用戶輸入信息
int user_input(Worker* w)
{
printf("ID:");
scanf("%d", &w->id);
getchar();//吸收回車字符
printf("name:");
gets_s(w->name);
printf("sex:");
gets_s(w->sex);
printf("age:");
scanf("%d", &w->age);
getchar();//吸收回車字符
printf("edu_exp:");
gets_s(w->edu_exp);
printf("wage:");
scanf("%d", &w->wage);
getchar();//吸收回車字符
printf("adress:");
gets_s(w->adress);
printf("phone:");
gets_s(w->phong);
return 0;
}
//添加對(duì)象
void add(Worker* w)
{
w->next = m_head.next;
m_head.next = w;
}
//按插入對(duì)象
int insert(Worker* w)
{
Worker* cur = m_head.next; // 當(dāng)前節(jié)點(diǎn)current
Worker* pre = &m_head; // 上一個(gè)節(jié)點(diǎn)previous
while (cur)
{
if (w->id < cur->id) // 找到這個(gè)位置
break;
pre = cur;
cur = cur->next; // 找到最后一個(gè)對(duì)象
}
// 插入到pre節(jié)點(diǎn)的后面
w->next = pre->next;
pre->next = w;
return 0;
}
//刪除對(duì)象
int remove(int id)
{
Worker* cur = m_head.next;//當(dāng)前節(jié)點(diǎn)為第一個(gè)對(duì)象
Worker* pre = &m_head;//當(dāng)前節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn),為頭節(jié)點(diǎn),指向第一個(gè)對(duì)象
while (cur)
{
if (id == cur->id)//找到要?jiǎng)h除的節(jié)點(diǎn)
{
pre->next = cur->next;
free(cur);//刪除該節(jié)點(diǎn)
return 1;//成功刪除返回1
}
pre = cur;
cur = cur->next;
}
return 0;
}
//查找對(duì)象
int find(int id)
{
Worker* p = m_head.next;
while (p)
{
if (id == p->id)
{
printf("ID:%d\nName:%s\nSex:%s\nAge:%d\nEdu-exp:%s\nWage:%d\nAdress:%s\nPhone:%s\n",
p->id, p->name, p->sex, p->age, p->edu_exp, p->wage, p->adress, p->phong);
return 1;//找到目標(biāo)返回1
}
p = p->next;
}
return 0;
}
//遍歷
void show_all()
{
Worker* p = m_head.next;
if (!p)
{
printf("暫無員工信息!\n");
return;
}
printf("工 號(hào) 姓 名 性 別 年 齡 學(xué) 歷 工 資 住 址 電 話\n");
printf("----------------------------------------------------------------\n");
while (p)
{
printf("%d %s %s %d %s %d %s %s\n", p->id, p->name, p->sex, p->age, p->edu_exp,
p->wage, p->adress, p->phong);
p = p->next;
}
}
//向文件存入數(shù)據(jù)
int save()
{
const char* filename = "F:\\data.txt";
FILE* fp = fopen(filename, "a");
if (fp == NULL)
{
printf("can not open the file....");
exit(0);
}
Worker* p = m_head.next;
while (p)
{
fprintf(fp, "\r");
fprintf(fp, "%d ", p->id);
fprintf(fp, "%s ", p->name);
fprintf(fp, "%s ", p->sex);
fprintf(fp, "%d ", p->age);
fprintf(fp, "%s ", p->edu_exp);
fprintf(fp, "%d ", p->wage);
fprintf(fp, "%s ", p->adress);
fprintf(fp, "%s ", p->phong);
fprintf(fp, "\t\r\n");
p = p->next;
}
fclose(fp);
return 0;
}
//修改對(duì)象
void rewrite(int id)
{
Worker* p = m_head.next;
while (p)
{
if (id == p->id)
{
user_input(p);
}
p = p->next;
}
}
//主菜單
void List()
{
Worker* w = NULL;
char key;
while (1)
{
do
{
system("cls");
printf("*******************************************************\n");
printf("* 主菜單操作界面 *\n");
printf("* *\n");
printf("* 1.錄入職工信息 *\n");
printf("* 2.瀏覽職工信息 *\n");
printf("* 3.查詢職工信息 *\n");
printf("* 4.刪除職工信息 *\n");
printf("* 5.修改職工信息 *\n");
printf("* 6.使用說明 *\n");
printf("* 7.退出 *\n");
printf("* *\n");
printf("*******************************************************\n");
key = getchar();
} while (key != '1'&&key != '2'&&key != '3'&&key != '4'
&&key != '5'&&key != '6'&&key != '7');
switch (key)
{
case '1':system("cls");
while (1)
{
Worker* w = (Worker*)malloc(sizeof(Worker));
user_input(w);
insert(w);
if (getchar() == 'N')
{
break;
}
}
save();
free(w);
break;
case '2':system("cls");
show_all();
system("pause");
break;
case '3':system("cls");
if (!m_head.next)
{
printf("暫無員工信息!\n");
system("pause");
break;
}
while (1)
{
int n;
printf("---------------------------------\n");
printf("請(qǐng)輸入要查找的ID號(hào):");
scanf("%d", &n);
if (!find(n))
{
printf("找不到ID號(hào)為%d 的職工信息...\n", n);
}
char ch = getchar();
if (ch == 'N')
{
break;
}
}
break;
case '4':system("cls");
if (!m_head.next)
{
printf("暫無員工信息!\n");
system("pause");
break;
}
while (1)
{
int n;
printf("---------------------------------\n");
printf("請(qǐng)輸入要?jiǎng)h除的ID號(hào):");
scanf("%d", &n);
if (remove(n))
{
printf("成功刪除ID號(hào)為%d的職工信息.\n", n);
}
else
printf("無法刪除ID號(hào)為%d的職工信息.\n", n);
char ch = getchar();
if (ch == 'N')//摁N退出
{
break;
}
}
break;
case '5':system("cls");//
if (!m_head.next)
{
printf("暫無員工信息!\n");
system("pause");
break;
}
while (1)
{
int n;
printf("請(qǐng)輸入要修改的ID號(hào):\n");
scanf("%d", &n);
printf("請(qǐng)修改:\n");
rewrite(n);
if (getchar() == 'N')
{
break;
}
}
break;
case '6':system("cls");
printf("職工系統(tǒng)使用說明:摁相應(yīng)數(shù)字進(jìn)入相應(yīng)的子菜單,若想退出則摁N\n開始無數(shù)據(jù),需要先進(jìn)行錄入.\n");
system("pause");
break;
case '7':system("cls");//
return;
break;
}
}
}
int main()
{
List();
return 0;
}
這是一個(gè)簡(jiǎn)單的小例子,主要是給大家一些思路,我這里只是簡(jiǎn)單的寫了保存輸入的數(shù)據(jù)到文件中,你也可用寫一個(gè)從文件中讀取數(shù)據(jù)到控制臺(tái),并且可以通過鏈表進(jìn)行修改.這就麻煩一點(diǎn),但是思路很簡(jiǎn)單.有興趣的同學(xué)可以do better.
推薦幾篇文章:
C++實(shí)現(xiàn)簡(jiǎn)單的圖書管理系統(tǒng)
C++實(shí)現(xiàn)簡(jiǎn)單的職工信息管理系統(tǒng)
關(guān)于管理系統(tǒng)的更多內(nèi)容請(qǐng)點(diǎn)擊《管理系統(tǒng)專題》進(jìn)行學(xué)習(xí)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 使用C語言中的time函數(shù)獲取系統(tǒng)時(shí)間
- C語言編寫學(xué)生成績(jī)管理系統(tǒng)
- C語言通訊錄管理系統(tǒng)完整版
- C語言實(shí)現(xiàn)圖書管理系統(tǒng)
- C語言學(xué)生管理系統(tǒng)源碼分享
- 基于C語言實(shí)現(xiàn)簡(jiǎn)單的12306火車售票系統(tǒng)
- C語言職工信息管理系統(tǒng)源碼
- C語言圖書管理系統(tǒng)簡(jiǎn)潔版
- C語言數(shù)據(jù)結(jié)構(gòu)之學(xué)生信息管理系統(tǒng)課程設(shè)計(jì)
- C語言實(shí)現(xiàn)小學(xué)生考試系統(tǒng)
相關(guān)文章
Qt中集成并使用SQLite數(shù)據(jù)庫的超完整指南
這篇文章主要介紹了Qt中集成并使用SQLite數(shù)據(jù)庫的相關(guān)資料,包括環(huán)境配置、連接數(shù)據(jù)庫、執(zhí)行SQL操作、事務(wù)處理、使用模型-視圖編程、錯(cuò)誤處理、高級(jí)技巧與注意事項(xiàng)以及常見問題解答,需要的朋友可以參考下2025-04-04
Qt實(shí)現(xiàn)編輯框失去焦點(diǎn)隱藏功能
這篇文章主要為大家詳細(xì)介紹了Qt實(shí)現(xiàn)的一個(gè)簡(jiǎn)單的編輯框操作——主窗口失去焦點(diǎn)隱藏功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2022-10-10
C語言深入細(xì)致講解動(dòng)態(tài)內(nèi)存管理
動(dòng)態(tài)內(nèi)存是相對(duì)靜態(tài)內(nèi)存而言的。所謂動(dòng)態(tài)和靜態(tài)就是指內(nèi)存的分配方式。動(dòng)態(tài)內(nèi)存是指在堆上分配的內(nèi)存,而靜態(tài)內(nèi)存是指在棧上分配的內(nèi)存,本文帶你深入探究C語言中動(dòng)態(tài)內(nèi)存的管理2022-05-05
C語言修煉之路初識(shí)分支句?循環(huán)助本心上篇
現(xiàn)實(shí)生活中我們經(jīng)常需要根據(jù)不同的條件做出不同的選擇。程序設(shè)計(jì)中也需要根據(jù)條件來選擇不同的程序進(jìn)行處理,這稱之為分支結(jié)構(gòu),當(dāng)條件表達(dá)式不存在時(shí),它被假設(shè)為真。您也可以設(shè)置一個(gè)初始值和增量表達(dá)式,一般情況下,C?程序員偏向于使用?for(;;)?結(jié)構(gòu)來表示一個(gè)無限循環(huán)2022-03-03
VSCode插件開發(fā)全攻略之package.json詳解
這篇文章主要介紹了VSCode插件開發(fā)全攻略之package.json的相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05

