首頁 > 軟體

C語言連結串列實現工資管理系統

2022-02-27 19:00:29

本文範例為大家分享了C語言連結串列實現工資管理系統的具體程式碼,供大家參考,具體內容如下

自己的作業,分享一下,自己為了偵錯方便,又多加入了一些功能

題目:建立工資管理系統,對職工工資的相關資訊進行管理。職工工資相關資訊包括職工工號,職工姓名,月份,每月工資和年度總工資等,具體要求如下:

1、建立該系統的儲存結構
2、錄入職工某個月的工資
3、查詢某個職工某個月的工資
4、修改某個職工某個月的工資
5、刪除每個職工的工資相關資訊
6、統計某個職工年度總工資
7、對職工的月工資或年度總工資進行排名

原始碼

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

typedef struct worker
{
    char no[12];         //職工工號
    char name[40];       //姓名
    int month[12];       //月份
    float gz[12];        //月工資
    float total;         //年度總工資
    struct worker *next; //指向下一節點的指標
} Worker;

//相關的函數宣告
Worker *CreateList(Worker *L, int n);               //根據輸入的職工人數,批次建立節點
void DeleteList(Worker *L, char n[]);               //刪除節點
void LIstSearch(Worker *L, char n[]);               //查詢職工工資資訊
void InsertInfo(Worker *L);                         //插入職工工資資訊
void SearchMonthSalary(Worker *L, char n[], int m); //查詢某個職工的某個月的工資
void Input(Worker *p, int i);                       //為節點的資料域賦值
void Print(Worker *L);                              //輸出整個連結串列的資料
void Modify(Worker *L, char n[], int m, float s);   //修改某個職工的工資
void menu();                                        //工資管理系統的選單
void Save(Worker *L);                               //將職工的工資資訊儲存至檔案
void Bubble_sort(Worker *L);                        //氣泡排序實現對連結串列節點的排序
void StatiTotal(Worker *L,char n[]);                //統計某個職工年度總工資

//根據輸入的職工人數,批次建立節點
Worker *CreateList(Worker *L, int n) //n為輸入的職工人數
{
    int i;
    for (i = 0; i < n; i++)
    {
        Worker *p;                                    //將新生成的節點插入到連結串列中
        p = NULL;
        p = (Worker *)malloc(sizeof(Worker));
        Input(p, i);                                //為節點的資料域賦值
        p->next = L->next;
        L->next = p;
    }
    return L;
}

void DeleteList(Worker *L, char n[]) //按姓名刪除職工資訊
{
    int i;
    Worker *p = L->next, *pre = L; //定義p指標指向頭節點的指向,定義pre指向頭節點,pre始終指向p的前驅節點
    if (p == NULL)
        printf("資料為空,無法刪除!");
    else
    {
        while (strcmp(p->name, n) != 0)
        {
            pre = p;
            p = pre->next;
            if (p == NULL)
            {
                printf("沒有找到相關資訊,無法刪除n");
                return;
            }
        }
        pre->next = p->next;
        free(p);
        printf("刪除成功");
    }
}

//向連結串列中插入職工工資資訊
void InsertInfo(Worker *L)
{
    int j, k;
    Worker *p = NULL;
    p = (Worker *)malloc(sizeof(Worker)); //生成一個新節點p
    p->total = 0;
    printf("請輸入要插入的職工的職工工號:");
    scanf("%s", &p->no);
    printf("請輸入要插入的職工的姓名:");
    scanf("%s", &p->name);
    for (k = 0, j = 1; j <= 12, k < 12; j++, k++)
        p->month[k] = j;
    printf("請輸入要插入的職工的月工資(用空格隔開):");
    for (j = 0; j < 12; j++)
    {
        scanf("%f", &p->gz[j]); //輸入每個月的工資
        p->total += p->gz[j];   //計算總工資
    }
    p->next = L->next;
    L->next = p;
    printf("插入成功!");
}

void LIstSearch(Worker *L, char n[])
{
    int i;
    Worker *p = L->next;
    while (p != NULL)
    {
        if (strcmp(p->name, n) == 0)
        {
            printf("n該職工的工資的資訊如下:n");
            printf("職工編號:");
            printf("%stn", p->no);
            printf("姓名:");
            printf("%sn", p->name);
            printf("該職工12個月的月工資如下:");
            for (i = 0; i < 12; i++)
                printf("%.2f ", p->gz[i]);
            printf("n該職工的年度總工資為:");
            printf("%.2f", p->total);
            printf("nn");
            printf("n");
            p = p->next;
        }
        else
            p = p->next;
    }
}

void SearchMonthSalary(Worker *L, char n[], int m)
{
    int i;
    Worker *p = L->next;
    while (p != NULL)
    {
        if (strcmp(p->name, n) == 0)
        {
            switch (m)
            {
            case 1:
                printf("該職工%d月的工資為%.2f", p->month[0], p->gz[0]);
                break;
            case 2:
                printf("該職工%d月的工資為%.2f", p->month[1], p->gz[1]);
                break;
            case 3:
                printf("該職工%d月的工資為%.2f", p->month[2], p->gz[2]);
                break;
            case 4:
                printf("該職工%d月的工資為%.2f", p->month[3], p->gz[3]);
                break;
            case 5:
                printf("該職工%d月的工資為%.2f", p->month[4], p->gz[4]);
                break;
            case 6:
                printf("該職工%d月的工資為%.2f", p->month[5], p->gz[5]);
                break;
            case 7:
                printf("該職工%d月的工資為%.2f", p->month[6], p->gz[6]);
                break;
            case 8:
                printf("該職工%d月的工資為%.2f", p->month[7], p->gz[7]);
                break;
            case 9:
                printf("該職工%d月的工資為%.2f", p->month[8], p->gz[8]);
                break;
            case 10:
                printf("該職工%d月的工資為%.2f", p->month[9], p->gz[9]);
                break;
            case 11:
                printf("該職工%d月的工資為%.2f", p->month[10], p->gz[10]);
                break;
            case 12:
                printf("該職工%d月的工資為%.2f", p->month[11], p->gz[11]);
                break;
            default:
                break;
            }
            p = p->next;
        }
        else
            p = p->next;
    }
}

void Bubble_sort(Worker *L)//氣泡排序實現對連結串列節點的排序
{
    Worker *p,*q,*tail,*l;
    tail = NULL;
    while((L->next->next) != tail)
    {
        p = L;
        q = L->next;
        while(q->next != tail)
        {
            if((q->total) > (q->next->total))
            {
                p->next = q->next;
                q->next = q->next->next;
                p->next->next = q;
                q = p->next;
            }
            q = q->next;
            p = p->next;
        }
        tail = q;
    }
    printf("排序完成!年度總工資從小到大結果如下:n");
    l=L->next;
    while(l!=NULL)
    {
        if(l->next!=NULL)
            {
                printf("%s->",l->name);
                l=l->next;
            }
        else
        {
            printf("%s",l->name);
            l=l->next;
        }
    }
}

void StatiTotal(Worker *L,char n[])         //統計某個職工年度總工資
{
    int i;
    Worker *p=L->next;
    while(p!=NULL)
    {
        p->total=0;
        if(strcmp(p->name,n)==0)
        {
            for(i=0;i<12;i++)
                p->total+=p->gz[i];
            printf("%s的年度總工資為%.2f",n,p->total);
            break;
        }
        else
            p=p->next;
    }

}

void Modify(Worker *L, char n[], int m, float s)
{
    int i,j;
    Worker *p = L->next;
    while (p != NULL)
    {
        if (strcmp(p->name, n) == 0)
        {
            switch (m)
            {
            case 1:
                p->gz[0] = s;
                break;
            case 2:
                p->gz[1] = s;
                break;
            case 3:
                p->gz[2] = s;
                break;
            case 4:
                p->gz[3] = s;
                break;
            case 5:
                p->gz[4] = s;
                break;
            case 6:
                p->gz[5] = s;
                break;
            case 7:
                p->gz[6] = s;
                break;
            case 8:
                p->gz[7] = s;
                break;
            case 9:
                p->gz[8] = s;
                break;
            case 10:
                p->gz[9] = s;
                break;
            case 11:
                p->gz[10] = s;
                break;
            case 12:
                p->gz[11] = s;
                break;
            default:
                break;
            }
            p->total=0;
            for(j=0;j<12;j++)
                p->total+=p->gz[j];
            p=p->next;
        }
        else
            p = p->next;
    }
    printf("修改成功!");
}
void Input(Worker *p, int i)
{
    int j, k;
    p->total = 0;
    printf("請輸入第%d名職工的職工工號:", i + 1);
    scanf("%s", &p->no);
    printf("請輸入第%d名職工的姓名:", i + 1);
    scanf("%s", &p->name);
    for (k = 0, j = 1; j <= 12, k < 12; j++, k++)
        p->month[k] = j;
    printf("請輸入第%d名職工的月工資(用空格隔開):", i + 1);
    for (j = 0; j < 12; j++)
    {
        scanf("%f", &p->gz[j]); //輸入每個月的工資
        p->total += p->gz[j];   //計算總工資
    }
}

void Print(Worker *L)       //列印所有職工工資資訊
{
    int i;
    Worker *p = L->next;
    while (p != NULL)
    {
        printf("職工編號:");
        printf("%stn", p->no);
        printf("姓名:");
        printf("%sn", p->name);
        printf("該職工12個月的月工資如下:");
        for (i = 0; i < 12; i++)
            printf("%.2f ", p->gz[i]);
        printf("n該職工的年度總工資為:");
        printf("%.2f", p->total);
        printf("nn");
        p = p->next;
    }
}

void Save(Worker *L)
{
    int i;
    Worker *p = L->next;
    FILE *fp = fopen("WorkerSalaryInfo.txt", "w");
    while (p != NULL)
    {
        fprintf(fp, "職工編號:");
        fprintf(fp, "%stn", p->no);
        fprintf(fp, "姓名:");
        fprintf(fp, "%sn", p->name);
        fprintf(fp, "該職工12個月的月工資如下:");
        for (i = 0; i < 12; i++)
            fprintf(fp, "%.2f ", p->gz[i]);
        fprintf(fp, "n該職工的年度總工資為:");
        fprintf(fp, "%.2f", p->total);
        fprintf(fp, "nn");
        p = p->next;
    }
    fclose(fp);
    printf("儲存成功,已儲存至當前目錄下的‘WorkerSalaryInfo.txt'檔案中");
}

void menu()
{
    printf("ttttt                                               n");
    printf("ttttt▔▔▔▔▔▔▔歡迎進入工資管理系統▔▔▔▔▔▔▔n");
    printf("ttttt1.錄入職工每個月的工資資訊                    n");
    printf("ttttt2.按姓名查詢某個員工各月的工資                n");
    printf("ttttt3.按姓名查詢某個職工的某個月的工資            n");
    printf("ttttt4.修改某個職工某個月的工資                    n");
    printf("ttttt5.刪除某個職工的相關資訊                         n");
    printf("ttttt6.插入職工工資資訊                            n");
    printf("ttttt7.統計某個職工年度總工資                        n");
    printf("ttttt8.對職工的年度總工資進行從小到大排名            n");
    printf("ttttt9.輸出所有職工工資資訊                        n");
    printf("ttttt10、將所有職工的工資資訊儲存至檔案            n");
    printf("ttttt0.退出                                    n");
    printf("ttttt▁▁▁▁▁▁▁▁▁▁謝謝使用▁▁▁▁▁▁▁▁▁n");
}

int main()
{
    int item, n, m; //item用於接收輸入的命令,n用於接收輸入的職工人數
    float s;
    char nam[10];
    Worker *L = (Worker*)malloc(sizeof(Worker));
    L->next=NULL;
    do
    {
        system("cls"); 
        menu();
        printf("n請輸入相應的數位,進行相應的操作:n");
        scanf("%d", &item);
        switch (item)
        {
        case 1:
            printf("請輸入您要錄入的職工人數:");
            scanf("%d", &n);
            L = CreateList(L, n);
            getchar();
            printf("n請按任意鍵返回主選單n");
            getchar();
            break;
        case 2:
            printf("請輸入您要查詢的職工姓名:");
            scanf("%s", &nam);
            LIstSearch(L, nam);
            getchar();
            printf("n請按任意鍵返回主選單n");
            getchar();
            break;
        case 3:
            printf("請輸入您要查詢的職工的姓名:");
            scanf("%s", &nam);
            printf("請輸入您要查詢該職工第幾個月的工資(1到12):");
            scanf("%d", &m);
            SearchMonthSalary(L, nam, m);
            getchar();
            printf("n請按任意鍵返回主選單n");
            getchar();
            break;
        case 4:
            printf("請輸入您要修改的職工姓名:");
            scanf("%s", &nam);
            printf("n請輸入您要修改的月份:");
            scanf("%d", &m);
            printf("n請輸入您修改後的資料:");
            scanf("%f", &s);
            Modify(L, nam, m, s);
            getchar();
            printf("n請按任意鍵返回主選單n");
            getchar();
            break;
        case 5:
            printf("請輸入您要刪除的職工姓名:");
            scanf("%s", &nam);
            DeleteList(L, nam);
            getchar();
            printf("n請按任意鍵返回主選單n");
            getchar();
            break;
        case 6:
            InsertInfo(L);
            getchar();
            printf("n請按任意鍵返回主選單n");
            getchar();
            break;
        case 7:
            printf("請輸入您要查詢的職工姓名:");
            scanf("%s",&nam);
            StatiTotal(L,nam);
            getchar();
            printf("n請按任意鍵返回主選單n");
            getchar();
            break;
        case 8:
            Bubble_sort(L);
            getchar();
            printf("n請按任意鍵返回主選單n");
            getchar();
            break;
        case 9:
            printf("全部職工的資訊如下:nn");
            Print(L);
            getchar();
            printf("n請按任意鍵返回主選單n");
            getchar();
            break;
        case 10:
            Save(L);
            getchar();
            printf("n請按任意鍵返回主選單n");
            getchar();
            break;
        case 0:
            printf("謝謝您使用工資管理系統,即將退出工資管理系統.....");
            exit(0);
            break;
        }
        printf("nnnn");
    } while (item);
    return 0;
}

部分執行結果截圖:

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com