C語言職工管理系統(tǒng)設(shè)計
本文實例為大家分享了C語言職工管理系統(tǒng)設(shè)計代碼,供大家參考,具體內(nèi)容如下
代碼如下:
#include<stdio.h> #include<stdlib.h> #include <string.h> struct Worker { int id;//工號 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; } //添加對象 void add(Worker* w) { w->next = m_head.next; m_head.next = w; } //按插入對象 int insert(Worker* w) { Worker* cur = m_head.next; // 當(dāng)前節(jié)點current Worker* pre = &m_head; // 上一個節(jié)點previous while (cur) { if (w->id < cur->id) // 找到這個位置 break; pre = cur; cur = cur->next; // 找到最后一個對象 } // 插入到pre節(jié)點的后面 w->next = pre->next; pre->next = w; return 0; } //刪除對象 int remove(int id) { Worker* cur = m_head.next;//當(dāng)前節(jié)點為第一個對象 Worker* pre = &m_head;//當(dāng)前節(jié)點的前一個節(jié)點,為頭節(jié)點,指向第一個對象 while (cur) { if (id == cur->id)//找到要刪除的節(jié)點 { pre->next = cur->next; free(cur);//刪除該節(jié)點 return 1;//成功刪除返回1 } pre = cur; cur = cur->next; } return 0; } //查找對象 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("工 號 姓 名 性 別 年 齡 學(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; } //修改對象 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("請輸入要查找的ID號:"); scanf("%d", &n); if (!find(n)) { printf("找不到ID號為%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("請輸入要刪除的ID號:"); scanf("%d", &n); if (remove(n)) { printf("成功刪除ID號為%d的職工信息.\n", n); } else printf("無法刪除ID號為%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("請輸入要修改的ID號:\n"); scanf("%d", &n); printf("請修改:\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; }
這是一個簡單的小例子,主要是給大家一些思路,我這里只是簡單的寫了保存輸入的數(shù)據(jù)到文件中,你也可用寫一個從文件中讀取數(shù)據(jù)到控制臺,并且可以通過鏈表進(jìn)行修改.這就麻煩一點,但是思路很簡單.有興趣的同學(xué)可以do better.
推薦幾篇文章:
關(guān)于管理系統(tǒng)的更多內(nèi)容請點擊《管理系統(tǒng)專題》進(jìn)行學(xué)習(xí)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C語言編程數(shù)據(jù)結(jié)構(gòu)的棧和隊列
本篇文章是C語言編程篇,主要為大家介紹C語言編程中的數(shù)據(jù)結(jié)構(gòu),詳細(xì)的講解了數(shù)據(jù)結(jié)構(gòu)的棧和隊列有需要的朋友可以借鑒參考下,希望可以有所幫助2021-09-09