C語言鏈表實(shí)現(xiàn)商品庫存管理系統(tǒng)
本文實(shí)例為大家分享了C語言鏈表實(shí)現(xiàn)商品庫存管理系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下
代碼:
#include <stdio.h> #include <stdlib.h> #include <string.h> //定義一個商品結(jié)構(gòu)體 typedef struct sp { ? ? char no[12]; ? ? //商品編號 ? ? char name[40]; ? //名稱 ? ? int workload; ? ?//庫存量 ? ? struct sp *next; //指向下一節(jié)點(diǎn)的指針 } SP; //函數(shù)聲明放在這里 void ListCreate(SP *L, int n); //創(chuàng)建商品鏈表節(jié)點(diǎn) void LIstSearch(SP *L); ? ? ? ?//查找商品信息 void ListModify(SP *L); ? ? ? ?//修改商品信息 void ListInsert(SP *L); ? ? ? ?//插入商品信息 void ListDelete(SP *L); ? ? ? ?//刪除商品信息 void Input(SP *p, int i); ? ? ?//輸入商品信息 void SumSp(SP *L); ? ? ? ? ? ? //統(tǒng)計商品的庫存總量 void Sort(SP *L); ? ? ? ? ? ? ?//對每類商品的庫存量進(jìn)行排名 void Menu(); ? ? ? ? ? ? ? ? ? //考試報名管理系統(tǒng)的菜單 //商品庫存管理系統(tǒng)的主函數(shù)入口 int main() { ? ? int item, n; ? ? ? ? ? ? ? ? ?//item用于接收輸入的命令,n用于接收輸入的商品人數(shù) ? ? SP *L = NULL; ? ? ? ? ? ? ? ? //初始化一個頭節(jié)點(diǎn) ? ? L = (SP *)malloc(sizeof(SP)); //為頭節(jié)點(diǎn)開辟內(nèi)存空間 ? ? L->next = NULL; ? ? ? ? ? ? ? //將頭節(jié)點(diǎn)的指針域置空 ? ? do ? ? { ? ? ? ? Menu(); //菜單 ? ? ? ? printf("請輸入相應(yīng)的數(shù)字,進(jìn)行相應(yīng)的操作:\n"); ? ? ? ? scanf("%d", &item); ? ? ? ? system("cls"); ? ? ? ? switch (item) ? ? ? ? { ? ? ? ? case 1: ? ? ? ? ? ? printf("請輸入您要錄入的商品數(shù)目:"); ? ? ? ? ? ? scanf("%d", &n); ? ? ? ? ? ? ListCreate(L, n);? ? ? ? ? ? ? getchar(); ? ? ? ? ? ? printf("\n請按任意鍵返回主菜單\n"); ? ? ? ? ? ? getchar(); ? ? ? ? ? ? system("cls"); ? ? ? ? ? ? break; ? ? ? ? case 2: ? ? ? ? ? ? LIstSearch(L); //查找商品信息 ? ? ? ? ? ? getchar(); ? ? ? ? ? ? printf("\n請按任意鍵返回主菜單\n"); ? ? ? ? ? ? getchar(); ? ? ? ? ? ? system("cls"); ? ? ? ? ? ? break; ? ? ? ? case 3: ? ? ? ? ? ? ListModify(L); //修改商品庫存信息 ? ? ? ? ? ? getchar(); ? ? ? ? ? ? printf("\n請按任意鍵返回主菜單\n"); ? ? ? ? ? ? getchar(); ? ? ? ? ? ? system("cls"); ? ? ? ? ? ? break; ? ? ? ? case 4: ? ? ? ? ? ? ListDelete(L); //刪除商品信息 ? ? ? ? ? ? getchar(); ? ? ? ? ? ? printf("\n請按任意鍵返回主菜單\n"); ? ? ? ? ? ? getchar(); ? ? ? ? ? ? system("cls"); ? ? ? ? ? ? break; ? ? ? ? case 5: ? ? ? ? ? ? ListInsert(L); //插入商品信息 ? ? ? ? ? ? getchar(); ? ? ? ? ? ? printf("\n請按任意鍵返回主菜單\n"); ? ? ? ? ? ? getchar(); ? ? ? ? ? ? system("cls"); ? ? ? ? ? ? break; ? ? ? ? case 6: ? ? ? ? ? ? SumSp(L); ? ? ? ? ? ? getchar(); ? ? ? ? ? ? printf("\n請按任意鍵返回主菜單\n"); ? ? ? ? ? ? getchar(); ? ? ? ? ? ? system("cls"); ? ? ? ? ? ? break; ? ? ? ? case 7: ? ? ? ? ? ? Sort(L); ? ? ? ? ? ? getchar(); ? ? ? ? ? ? printf("\n請按任意鍵返回主菜單\n"); ? ? ? ? ? ? getchar(); ? ? ? ? ? ? system("cls"); ? ? ? ? ? ? break; ? ? ? ? case 0: //退出商品庫存管理系統(tǒng) ? ? ? ? ? ? printf("即將退出商品庫存管理系統(tǒng)....."); ? ? ? ? ? ? exit(0); ? ? ? ? default: ? ? ? ? ? ? printf("您輸入的指令不正確,請重新輸入"); ? ? ? ? } ? ? ? ? printf("\n\n"); ? ? } while (item); ? ? return 0; } //創(chuàng)建鏈表,將新生成的節(jié)點(diǎn)插入到鏈表的表頭 void ListCreate(SP *L, int n) { ? ? int i; ? ? for (i = 0; i < n; i++) ? ? { ? ? ? ? SP *p; ? ? ? ? //將新生成的節(jié)點(diǎn)插入到鏈表中 ? ? ? ? p = NULL; ? ? ? ? p = (SP *)malloc(sizeof(SP)); ? ? ? ? Input(p, i); ? ? ? ? p->next = L->next; ? ? ? ? L->next = p; ? ? } ? ? printf("錄入成功!"); } //查找商品庫存量 void LIstSearch(SP *L) { ? ? char n[40]; ? ? SP *p = L->next; ? ? if (p == NULL) ? ? ? ? printf("數(shù)據(jù)為空,無法查找!"); ? ? else ? ? { ? ? ? ? printf("請輸入您要查找的商品名稱:"); ? ? ? ? scanf("%s", n); ? ? ? ? while (strcmp(p->name, n) != 0) ? ? ? ? { ? ? ? ? ? ? p = p->next; ? ? ? ? ? ? if (p == NULL) ? ? ? ? ? ? { ? ? ? ? ? ? ? ? printf("沒有找到相關(guān)信息\n"); ? ? ? ? ? ? ? ? return; ? ? ? ? ? ? } ? ? ? ? } ? ? ? ? printf("%s的庫存量為%d\n",p->name,p->workload); ? ? } } //修改商品的庫存量 void ListModify(SP *L) { ? ? int a; ? ? char nam[40]; ? ? SP *p = L->next; ? ? if (p == NULL) ? ? ? ? printf("數(shù)據(jù)為空,無法修改!"); ? ? else ? ? { ? ? ? ? printf("請輸入您修改的商品名稱:"); ? ? ? ? scanf("%s",nam); ? ? ? ? while(strcmp(p->name, nam) != 0) ? ? ? ? { ? ? ? ? ? ? p = p->next; ? ? ? ? ? ? if (p == NULL) ? ? ? ? ? ? { ? ? ? ? ? ? ? ? printf("沒有找到相關(guān)信息\n"); ? ? ? ? ? ? ? ? return; ? ? ? ? ? ? } ? ? ? ? } ? ? ? ? printf("請輸入您修改后的庫存量:"); ? ? ? ? scanf("%d",&p->workload); ? ? ? ? printf("修改成功"); ? ? } } //刪除商品信息 void ListDelete(SP *L) { ? ? char n[40]; ? ? SP *p = L->next, *pre = L; //定義p指針指向頭節(jié)點(diǎn)的指向,定義pre指向頭節(jié)點(diǎn),pre始終指向p的前驅(qū)節(jié)點(diǎn) ? ? if (p == NULL) ? ? ? ? printf("數(shù)據(jù)為空,無法刪除!"); ? ? else ? ? { ? ? ? ? printf("請輸入您要刪除的商品名稱:"); ? ? ? ? scanf("%s", n); ? ? ? ? while (strcmp(p->name, n) != 0) ? ? ? ? { ? ? ? ? ? ? pre = p; ? ? ? ? ? ? p = pre->next; ? ? ? ? ? ? if (p == NULL) ? ? ? ? ? ? { ? ? ? ? ? ? ? ? printf("沒有找到相關(guān)信息,無法刪除\n"); ? ? ? ? ? ? ? ? return; ? ? ? ? ? ? } ? ? ? ? } ? ? ? ? pre->next = p->next; ? ? ? ? free(p); ? ? ? ? printf("刪除成功"); ? ? } } //插入商品庫存的相關(guān)信息 void ListInsert(SP *L) { ? ? SP *s = NULL; //生成一個新節(jié)點(diǎn)s ? ? s = (SP *)malloc(sizeof(SP)); ? ? printf("請輸入商品的商品編號:"); ? ? scanf("%s", s->no); ? ? printf("請輸入商品的名稱:"); ? ? scanf("%s", s->name); ? ? printf("請輸入商品的庫存量:"); ? ? scanf("%d", &s->workload); ? ? s->next = L->next; ? ? L->next = s; ? ? printf("插入成功!"); } //統(tǒng)計商品的庫存總量 void SumSp(SP *L) { ? ? int sum=0; ? ? SP *p=L->next; ? ? while(p!=NULL) ? ? { ? ? ? ? sum+=p->workload; ? ? ? ? p=p->next; ? ? } ? ? printf("商品的庫存總量為%d\n",sum); ? ? } //對每類商品的庫存量進(jìn)行排名 void Sort(SP *L) { ? ? SP *p,*q,*tail,*l; ? ? tail=NULL; ? ? while((L->next->next) != tail) ? ? { ? ? ? ? p = L; ? ? ? ? q = L->next; ? ? ? ? while(q->next != tail) ? ? ? ? { ? ? ? ? ? ? if((q->workload) > (q->next->workload)) ? ? ? ? ? ? { ? ? ? ? ? ? ? ? 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("商品庫存量從小到大結(jié)果如下:\n"); ? ? l=L->next; ? ? while(l!=NULL) ? ? { ? ? ? ? if(l->next!=NULL) ? ? ? ? ? ? { ? ? ? ? ? ? ? ? printf("%s(%d)->",l->name,l->workload); ? ? ? ? ? ? ? ? l=l->next; ? ? ? ? ? ? } ? ? ? ? else ? ? ? ? { ? ? ? ? ? ? printf("%s(%d)",l->name,l->workload); ? ? ? ? ? ? l=l->next; ? ? ? ? } ? ? } } //輸入商品庫存的相關(guān)信息 void Input(SP *p, int i) { ? ? printf("請輸入第%d個商品的商品編號:", i + 1); ? ? scanf("%s", p->no); ? ? printf("請輸入第%d個商品的名稱:", i + 1); ? ? scanf("%s", p->name); ? ? printf("請輸入第%d個商品的庫存量:", i + 1); ? ? scanf("%d", &p->workload); } //商品庫存管理系統(tǒng)的菜單 void Menu() { ? ? printf("\n\n"); ? ? printf("\t\t\t===================商品庫存管理系統(tǒng)======================\n"); ? ? printf("\t\t\t* 作者:XXX ?班級:XXXXXXXXXXX ?學(xué)號:XXXXXXXXXX ? ? ? ? ? *\n"); ? ? printf("\t\t\t* ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? *\n"); ? ? printf("\t\t\t* ? ? ? ? ?1>. 錄入商品庫存信息 ? ? ? ? ? ? ? ? ? ? ? ? *\n"); ? ? printf("\t\t\t* ? ? ? ? ?2>. 查找某個商品的庫存量 ? ? ? ? ? ? ? ? ? ? *\n"); ? ? printf("\t\t\t* ? ? ? ? ?3>. 修改某個商品的庫存量 ? ? ? ? ? ? ? ? ? ? *\n"); ? ? printf("\t\t\t* ? ? ? ? ?4>. 刪除某個商品庫存相關(guān)信息 ? ? ? ? ? ? ? ? *\n"); ? ? printf("\t\t\t* ? ? ? ? ?5>. 插入某個商品的相關(guān)信息 ? ? ? ? ? ? ? ? ? *\n"); ? ? printf("\t\t\t* ? ? ? ? ?6>. 統(tǒng)計商品的庫存總量 ? ? ? ? ? ? ? ? ? ? ? *\n"); ? ? printf("\t\t\t* ? ? ? ? ?7>. 對每類商品的庫存量排名 ? ? ? ? ? ? ? ? ? *\n"); ? ? printf("\t\t\t* ? ? ? ? ?0>. 退出管理系統(tǒng) ? ? ? ? ? ? ? ? ? ? ? ? ? ? *\n"); ? ? printf("\t\t\t* ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?歡迎使用本系統(tǒng)!*\n"); ? ? printf("\t\t\t========================================================\n"); ? ? printf("\t\t\t輸入選項,按回車進(jìn)入選項: ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? \n"); }
部分運(yùn)行結(jié)果截圖
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
基于C語言實(shí)現(xiàn)計算生辰八字五行的示例詳解
生辰八字,簡稱八字,是指一個人出生時的干支歷日期;年月日時共四柱干支,每柱兩字,合共八個字。這篇文章主要介紹了C語言實(shí)現(xiàn)計算生辰八字五行的示例代碼,需要的可以參考一下2023-03-03C語言實(shí)現(xiàn)的順序表功能完整實(shí)例
這篇文章主要介紹了C語言實(shí)現(xiàn)的順序表功能,結(jié)合完整實(shí)例形式分析了C語言順序表的創(chuàng)建、添加、刪除、排序、合并等相關(guān)操作技巧,需要的朋友可以參考下2018-04-04OpenCV實(shí)現(xiàn)特征檢測和特征匹配方法匯總
一幅圖像中總存在著其獨(dú)特的像素點(diǎn),這些點(diǎn)我們可以認(rèn)為就是這幅圖像的特征,成為特征點(diǎn),本文主要介紹了OpenCV實(shí)現(xiàn)特征檢測和特征匹配方法,感興趣的可以了解一下2021-08-08如何通過函數(shù)指針調(diào)用函數(shù)(實(shí)現(xiàn)代碼)
指針可以不但可以指向一個整形,浮點(diǎn)型,字符型,字符串型的變量,也可以指向相應(yīng)的數(shù)組,而且還可以指向一個函數(shù)2013-09-09探討:將兩個鏈表非降序合并為一個鏈表并依然有序的實(shí)現(xiàn)方法
本篇文章是對將兩個鏈表非降序合并為一個鏈表并依然有序的實(shí)現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05C++中SetConsoleCursorPosition()移動光標(biāo)函數(shù)的用法大全
這篇文章主要介紹了C++中SetConsoleCursorPosition()移動光標(biāo)函數(shù)的用法大全,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03c++ 求數(shù)組最大最小值函數(shù)的實(shí)現(xiàn)
這篇文章主要介紹了c++ 求數(shù)組最大最小值函數(shù)的實(shí)現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07