C語言鏈表實現(xiàn)商品庫存管理系統(tǒng)
更新時間:2022年02月27日 16:29:51 作者:xjfyt
這篇文章主要為大家詳細(xì)介紹了C語言鏈表實現(xiàn)商品庫存管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了C語言鏈表實現(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é)點的指針
} 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 ?學(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輸入選項,按回車進入選項: ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? \n");
}部分運行結(jié)果截圖





以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
如何通過函數(shù)指針調(diào)用函數(shù)(實現(xiàn)代碼)
指針可以不但可以指向一個整形,浮點型,字符型,字符串型的變量,也可以指向相應(yīng)的數(shù)組,而且還可以指向一個函數(shù)2013-09-09
探討:將兩個鏈表非降序合并為一個鏈表并依然有序的實現(xiàn)方法
本篇文章是對將兩個鏈表非降序合并為一個鏈表并依然有序的實現(xiàn)方法進行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
C++中SetConsoleCursorPosition()移動光標(biāo)函數(shù)的用法大全
這篇文章主要介紹了C++中SetConsoleCursorPosition()移動光標(biāo)函數(shù)的用法大全,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03
c++ 求數(shù)組最大最小值函數(shù)的實現(xiàn)
這篇文章主要介紹了c++ 求數(shù)組最大最小值函數(shù)的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07

