C語(yǔ)言鏈表實(shí)現(xiàn)商品庫(kù)存管理系統(tǒng)
本文實(shí)例為大家分享了C語(yǔ)言鏈表實(shí)現(xiàn)商品庫(kù)存管理系統(tǒng)的具體代碼,供大家參考,具體內(nèi)容如下
代碼:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
//定義一個(gè)商品結(jié)構(gòu)體
typedef struct sp
{
? ? char no[12]; ? ? //商品編號(hào)
? ? char name[40]; ? //名稱
? ? int workload; ? ?//庫(kù)存量
? ? 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)計(jì)商品的庫(kù)存總量
void Sort(SP *L); ? ? ? ? ? ? ?//對(duì)每類商品的庫(kù)存量進(jìn)行排名
void Menu(); ? ? ? ? ? ? ? ? ? //考試報(bào)名管理系統(tǒng)的菜單
//商品庫(kù)存管理系統(tǒng)的主函數(shù)入口
int main()
{
? ? int item, n; ? ? ? ? ? ? ? ? ?//item用于接收輸入的命令,n用于接收輸入的商品人數(shù)
? ? SP *L = NULL; ? ? ? ? ? ? ? ? //初始化一個(gè)頭節(jié)點(diǎn)
? ? L = (SP *)malloc(sizeof(SP)); //為頭節(jié)點(diǎn)開(kāi)辟內(nèi)存空間
? ? L->next = NULL; ? ? ? ? ? ? ? //將頭節(jié)點(diǎn)的指針域置空
? ? do
? ? {
? ? ? ? Menu(); //菜單
? ? ? ? printf("請(qǐng)輸入相應(yīng)的數(shù)字,進(jìn)行相應(yīng)的操作:\n");
? ? ? ? scanf("%d", &item);
? ? ? ? system("cls");
? ? ? ? switch (item)
? ? ? ? {
? ? ? ? case 1:
? ? ? ? ? ? printf("請(qǐng)輸入您要錄入的商品數(shù)目:");
? ? ? ? ? ? scanf("%d", &n);
? ? ? ? ? ? ListCreate(L, n);?
? ? ? ? ? ? getchar();
? ? ? ? ? ? printf("\n請(qǐng)按任意鍵返回主菜單\n");
? ? ? ? ? ? getchar();
? ? ? ? ? ? system("cls");
? ? ? ? ? ? break;
? ? ? ? case 2:
? ? ? ? ? ? LIstSearch(L); //查找商品信息
? ? ? ? ? ? getchar();
? ? ? ? ? ? printf("\n請(qǐng)按任意鍵返回主菜單\n");
? ? ? ? ? ? getchar();
? ? ? ? ? ? system("cls");
? ? ? ? ? ? break;
? ? ? ? case 3:
? ? ? ? ? ? ListModify(L); //修改商品庫(kù)存信息
? ? ? ? ? ? getchar();
? ? ? ? ? ? printf("\n請(qǐng)按任意鍵返回主菜單\n");
? ? ? ? ? ? getchar();
? ? ? ? ? ? system("cls");
? ? ? ? ? ? break;
? ? ? ? case 4:
? ? ? ? ? ? ListDelete(L); //刪除商品信息
? ? ? ? ? ? getchar();
? ? ? ? ? ? printf("\n請(qǐng)按任意鍵返回主菜單\n");
? ? ? ? ? ? getchar();
? ? ? ? ? ? system("cls");
? ? ? ? ? ? break;
? ? ? ? case 5:
? ? ? ? ? ? ListInsert(L); //插入商品信息
? ? ? ? ? ? getchar();
? ? ? ? ? ? printf("\n請(qǐng)按任意鍵返回主菜單\n");
? ? ? ? ? ? getchar();
? ? ? ? ? ? system("cls");
? ? ? ? ? ? break;
? ? ? ? case 6:
? ? ? ? ? ? SumSp(L);
? ? ? ? ? ? getchar();
? ? ? ? ? ? printf("\n請(qǐng)按任意鍵返回主菜單\n");
? ? ? ? ? ? getchar();
? ? ? ? ? ? system("cls");
? ? ? ? ? ? break;
? ? ? ? case 7:
? ? ? ? ? ? Sort(L);
? ? ? ? ? ? getchar();
? ? ? ? ? ? printf("\n請(qǐng)按任意鍵返回主菜單\n");
? ? ? ? ? ? getchar();
? ? ? ? ? ? system("cls");
? ? ? ? ? ? break;
? ? ? ? case 0: //退出商品庫(kù)存管理系統(tǒng)
? ? ? ? ? ? printf("即將退出商品庫(kù)存管理系統(tǒng).....");
? ? ? ? ? ? exit(0);
? ? ? ? default:
? ? ? ? ? ? printf("您輸入的指令不正確,請(qǐng)重新輸入");
? ? ? ? }
? ? ? ? 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("錄入成功!");
}
//查找商品庫(kù)存量
void LIstSearch(SP *L)
{
? ? char n[40];
? ? SP *p = L->next;
? ? if (p == NULL)
? ? ? ? printf("數(shù)據(jù)為空,無(wú)法查找!");
? ? else
? ? {
? ? ? ? printf("請(qǐng)輸入您要查找的商品名稱:");
? ? ? ? scanf("%s", n);
? ? ? ? while (strcmp(p->name, n) != 0)
? ? ? ? {
? ? ? ? ? ? p = p->next;
? ? ? ? ? ? if (p == NULL)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? printf("沒(méi)有找到相關(guān)信息\n");
? ? ? ? ? ? ? ? return;
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? printf("%s的庫(kù)存量為%d\n",p->name,p->workload);
? ? }
}
//修改商品的庫(kù)存量
void ListModify(SP *L)
{
? ? int a;
? ? char nam[40];
? ? SP *p = L->next;
? ? if (p == NULL)
? ? ? ? printf("數(shù)據(jù)為空,無(wú)法修改!");
? ? else
? ? {
? ? ? ? printf("請(qǐng)輸入您修改的商品名稱:");
? ? ? ? scanf("%s",nam);
? ? ? ? while(strcmp(p->name, nam) != 0)
? ? ? ? {
? ? ? ? ? ? p = p->next;
? ? ? ? ? ? if (p == NULL)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? printf("沒(méi)有找到相關(guān)信息\n");
? ? ? ? ? ? ? ? return;
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? printf("請(qǐng)輸入您修改后的庫(kù)存量:");
? ? ? ? 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ù)為空,無(wú)法刪除!");
? ? else
? ? {
? ? ? ? printf("請(qǐng)輸入您要?jiǎng)h除的商品名稱:");
? ? ? ? scanf("%s", n);
? ? ? ? while (strcmp(p->name, n) != 0)
? ? ? ? {
? ? ? ? ? ? pre = p;
? ? ? ? ? ? p = pre->next;
? ? ? ? ? ? if (p == NULL)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? printf("沒(méi)有找到相關(guān)信息,無(wú)法刪除\n");
? ? ? ? ? ? ? ? return;
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? pre->next = p->next;
? ? ? ? free(p);
? ? ? ? printf("刪除成功");
? ? }
}
//插入商品庫(kù)存的相關(guān)信息
void ListInsert(SP *L)
{
? ? SP *s = NULL; //生成一個(gè)新節(jié)點(diǎn)s
? ? s = (SP *)malloc(sizeof(SP));
? ? printf("請(qǐng)輸入商品的商品編號(hào):");
? ? scanf("%s", s->no);
? ? printf("請(qǐng)輸入商品的名稱:");
? ? scanf("%s", s->name);
? ? printf("請(qǐng)輸入商品的庫(kù)存量:");
? ? scanf("%d", &s->workload);
? ? s->next = L->next;
? ? L->next = s;
? ? printf("插入成功!");
}
//統(tǒng)計(jì)商品的庫(kù)存總量
void SumSp(SP *L)
{
? ? int sum=0;
? ? SP *p=L->next;
? ? while(p!=NULL)
? ? {
? ? ? ? sum+=p->workload;
? ? ? ? p=p->next;
? ? }
? ? printf("商品的庫(kù)存總量為%d\n",sum); ? ?
}
//對(duì)每類商品的庫(kù)存量進(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("商品庫(kù)存量從小到大結(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;
? ? ? ? }
? ? }
}
//輸入商品庫(kù)存的相關(guān)信息
void Input(SP *p, int i)
{
? ? printf("請(qǐng)輸入第%d個(gè)商品的商品編號(hào):", i + 1);
? ? scanf("%s", p->no);
? ? printf("請(qǐng)輸入第%d個(gè)商品的名稱:", i + 1);
? ? scanf("%s", p->name);
? ? printf("請(qǐng)輸入第%d個(gè)商品的庫(kù)存量:", i + 1);
? ? scanf("%d", &p->workload);
}
//商品庫(kù)存管理系統(tǒng)的菜單
void Menu()
{
? ? printf("\n\n");
? ? printf("\t\t\t===================商品庫(kù)存管理系統(tǒng)======================\n");
? ? printf("\t\t\t* 作者:XXX ?班級(jí):XXXXXXXXXXX ?學(xué)號(hào):XXXXXXXXXX ? ? ? ? ? *\n");
? ? printf("\t\t\t* ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? *\n");
? ? printf("\t\t\t* ? ? ? ? ?1>. 錄入商品庫(kù)存信息 ? ? ? ? ? ? ? ? ? ? ? ? *\n");
? ? printf("\t\t\t* ? ? ? ? ?2>. 查找某個(gè)商品的庫(kù)存量 ? ? ? ? ? ? ? ? ? ? *\n");
? ? printf("\t\t\t* ? ? ? ? ?3>. 修改某個(gè)商品的庫(kù)存量 ? ? ? ? ? ? ? ? ? ? *\n");
? ? printf("\t\t\t* ? ? ? ? ?4>. 刪除某個(gè)商品庫(kù)存相關(guān)信息 ? ? ? ? ? ? ? ? *\n");
? ? printf("\t\t\t* ? ? ? ? ?5>. 插入某個(gè)商品的相關(guān)信息 ? ? ? ? ? ? ? ? ? *\n");
? ? printf("\t\t\t* ? ? ? ? ?6>. 統(tǒng)計(jì)商品的庫(kù)存總量 ? ? ? ? ? ? ? ? ? ? ? *\n");
? ? printf("\t\t\t* ? ? ? ? ?7>. 對(duì)每類商品的庫(kù)存量排名 ? ? ? ? ? ? ? ? ? *\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輸入選項(xiàng),按回車進(jìn)入選項(xiàng): ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? \n");
}部分運(yùn)行結(jié)果截圖





以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Windows注冊(cè)表中修改UAC(用戶賬號(hào)控制)及批處理腳本
今天小編就為大家分享一篇關(guān)于Windows注冊(cè)表中修改UAC(用戶賬號(hào)控制)及批處理腳本,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2018-12-12
C++程序中main(int argc, char *argv[])函數(shù)的參數(shù)意義
這篇文章主要介紹了C++程序中main(int argc, char *argv[])函數(shù)的參數(shù)意義,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09
C語(yǔ)言基于EasyX實(shí)現(xiàn)貪吃蛇
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言基于EasyX實(shí)現(xiàn)貪吃蛇,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06
C/C++使用Zlib實(shí)現(xiàn)文件的壓縮與解壓
zlib 是一個(gè)開(kāi)源的數(shù)據(jù)壓縮庫(kù),旨在提供高效、輕量級(jí)的壓縮和解壓縮算法,本文將介紹如何使用 zlib 庫(kù)進(jìn)行數(shù)據(jù)的壓縮和解壓縮,以及如何保存和讀取壓縮后的文件,感興趣的可以了解下2023-11-11
Visual Studio 2019 Professional 激活方法詳解
這篇文章主要介紹了Visual Studio 2019 Professional 激活方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05

