網(wǎng)站首頁 編程語言 正文
本文實例為大家分享了C語言鏈表實現(xiàn)商品庫存管理系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下
代碼:
#include#include #include //定義一個商品結(jié)構(gòu)體 typedef struct sp { ? ? char no[12]; ? ? //商品編號 ? ? char name[40]; ? //名稱 ? ? int workload; ? ?//庫存量 ? ? struct sp *next; //指向下一節(jié)點的指針 } SP; //函數(shù)聲明放在這里 void ListCreate(SP *L, int n); //創(chuàng)建商品鏈表節(jié)點 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); ? ? ? ? ? ? ?//對每類商品的庫存量進行排名 void Menu(); ? ? ? ? ? ? ? ? ? //考試報名管理系統(tǒng)的菜單 //商品庫存管理系統(tǒng)的主函數(shù)入口 int main() { ? ? int item, n; ? ? ? ? ? ? ? ? ?//item用于接收輸入的命令,n用于接收輸入的商品人數(shù) ? ? SP *L = NULL; ? ? ? ? ? ? ? ? //初始化一個頭節(jié)點 ? ? L = (SP *)malloc(sizeof(SP)); //為頭節(jié)點開辟內(nèi)存空間 ? ? L->next = NULL; ? ? ? ? ? ? ? //將頭節(jié)點的指針域置空 ? ? do ? ? { ? ? ? ? Menu(); //菜單 ? ? ? ? printf("請輸入相應(yīng)的數(shù)字,進行相應(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é)點插入到鏈表的表頭 void ListCreate(SP *L, int n) { ? ? int i; ? ? for (i = 0; i < n; i++) ? ? { ? ? ? ? SP *p; ? ? ? ? //將新生成的節(jié)點插入到鏈表中 ? ? ? ? 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é)點的指向,定義pre指向頭節(jié)點,pre始終指向p的前驅(qū)節(jié)點 ? ? 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é)點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); ? ? } //對每類商品的庫存量進行排名 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 ?學號: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輸入選項,按回車進入選項: ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? \n"); }
部分運行結(jié)果截圖
原文鏈接:https://blog.csdn.net/qq_29183811/article/details/106147881
相關(guān)推薦
- 2022-05-11 使用git命令上傳代碼_其它綜合
- 2022-10-19 Pandas如何將表格的前幾行生成html實戰(zhàn)案例_python
- 2022-11-04 詳解linux命令查看服務(wù)器上的實時日志_服務(wù)器其它
- 2022-10-17 QT實現(xiàn)TCP網(wǎng)絡(luò)聊天室_C 語言
- 2022-07-18 Stack和Queue容器的系列操作( 詳解 )
- 2023-01-12 Redis中Bloom?filter布隆過濾器的學習_Redis
- 2022-11-14 elasticsearch 性能優(yōu)化
- 2022-07-13 二叉樹的創(chuàng)建和前序,中序,后序遍歷(詳細)
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支