数据结构:顺序表的应用--仓库货物管理信息管理系统

本文主要是介绍数据结构:顺序表的应用--仓库货物管理信息管理系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

分析下列功能需求,自定义存储货物的结构体类型以及顺序表类型,并以初始化方式提供初始的一些货物信息表。

(1)并输出所有货物信息。

(2)按商品编号查询,并显示查询结果。

(3)删除某个货物(在二级菜单中选择是按商品编号还是按商品名称进行删除)。

(4)按商品库存的升序进行排序。

(5)完成入库管理:当一个货物要入库时,首先确定它是否是一个新的货物,如果不是新的,则查询到该货物并修改其数量,如果是新货物,则要确定新的货物号码,同时录入其信息并将其插入到货物表中。

(6)完成出库管理:当用户需要一定数量的货物名时,首先查询有没有这个货物,如果有且数量足够,则出库并修改该货物数量,如果数量不足则给出相应信息。如果没有该货物,则也给出提示信息。

(7)统计显示目前所有商品库存的总数量。

(8)查询出所有库存为0的商品信息。

#include<stdio.h>
#include<windows.h>
#include<stdlib.h>
#define MAXSIZE 100typedef struct goods
{char name[10]; int num;       int stock;     
}GOODS;typedef struct  
{GOODS data[MAXSIZE+1];int len;
}SeqList;void look(SeqList t);
int  search(SeqList *L,GOODS x);
void menu();
void delete_SeqList(SeqList *L,int i); 
void come(SeqList *L,int i,GOODS v);
void out(SeqList *L,int k,GOODS z);
int nowstock(SeqList *L);
void stockiszero(SeqList *L);
void rank(SeqList *L); int main()
{SeqList t={{{"",0,0},{"黑笔",1,100},{"红笔",2,10},{"蓝笔",3,20}},3};int m;	do{system("cls");menu();printf("请输入你的选择:\n");scanf("%d",&m);switch(m){case 1: look(t);system("pause");break;case 2:	GOODS x;int k;printf("请输入你要查询的商品编号:");scanf("%d",&x.num);search(&t,x);k=search(&t,x);if(k==0){printf("该商品不存在");}else{printf("货物名称  货物代号 货物数量\n");printf("%4s%8d%12d\n",t.data[k].name,t.data[k].num,t.data[k].stock);}system("pause");    break;case 3: GOODS n;int b;printf("请输入你想要删除的商品编号:");scanf("%d",&n.num);delete_SeqList(&t,n.num);system("pause");break;case 4: rank(&t);system("pause");  break;case 5: GOODS y;int q;printf("请输入你想要入库货物的编号"); scanf("%d",&y.num); q=search(&t,y);if(q==0){printf("您入库的是新商品,请录入货物信息\n");printf("请输入商品名称、编号、数量:\n");scanf("%s%d%d",y.name,&y.num,&y.stock);come(&t,t.len+1,y);}else {printf("请输入商品的入库数量:");scanf("%d",&y.stock);t.data[q].stock+=y.stock;}system("pause");  break;case 6:	GOODS z;printf("请输入想要出库的货物编号:");scanf("%d",&z.num);k=search(&t,z);out(&t,k,z);system("pause");  break;case 7:	int alls;alls=nowstock(&t);printf("目前所有商品库存的总数量=%d\n",alls);system("pause"); break;case 8:	stockiszero(&t);system("pause"); break;}}while(m!=9);return 0;	   
}
void menu()
{printf("仓库货物管理信息管理系统\n");printf("请输入数字来实现以下操作:\n");printf("1.输出所有货物信息\n");printf("2.查询商品\n");printf("3.删除货物\n");printf("4.按商品库存数量的升序进行排序\n");printf("5.商品入库\n");printf("6.商品出库\n");printf("7.显示商品总数量\n");printf("8.查询所有库存为0的商品信息\n");printf("  (如果无商品信息输出则说明仓库商品都有库存)\n"); printf("9.退出\n");
}
void look(SeqList t)
{int i;printf("         货物清单     \n\n");printf("货物名称  货物代号 货物数量\n");for(i=1;i<=t.len;i++){printf("%4s%8d%12d\n",t.data[i].name,t.data[i].num,t.data[i].stock);}
}
int search(SeqList *L,GOODS x)
{int i=1;while(i<=L->len&&L->data[i].num!=x.num)i++;if(i>(L->len))return 0;else return i; 
}
void delete_SeqList(SeqList *L,int i)
{int j;if(L->len==0){printf("The List is empty!");}else if(i<1||i>L->len){printf("this element don't exist!");}for(j=i+1;j<=L->len;j++)L->data[j-1]=L->data[j];L->len--; 
}
void come(SeqList *L,int i,GOODS y)
{int j;if(L->len==MAXSIZE-1){printf("表已满,无法插入!"); }else if(i<1||i>(L->len+1)){printf("插入位置不正确!");}else{for(j=L->len;j>=i;j--)L->data[j+1]=L->data[j];L->data[i]=y;L->len++;}
}
void out(SeqList *L,int k,GOODS z)
{int i,m;if(k==0){printf("对不起,仓库没有此货物!\n");}else{printf("请输入出库数量:");scanf("%d",&m);if(L->data[k].stock<m){printf("对不起,库存不足!\n");}else{L->data[k].stock=L->data[k].stock-m;printf("出库成功!\n"); }}
}
int nowstock(SeqList *L)
{int i;int all;for(i=0;i<L->len+1;i++){all+=L->data[i].stock;}return all;
}
void stockiszero(SeqList *L)
{int i; for(i=1;i<=L->len;i++){if(L->data[i].stock==0){printf("货物名称  货物代号 货物数量\n");printf("%4s%8d%12d\n",L->data[i].name,L->data[i].num,L->data[i].stock);}else{printf("%s的库存还有%d\n",L->data[i].name,L->data[i].stock);}	} 
}
void rank(SeqList *L)
{int i,j;GOODS g;for(i=0;i<L->len-1;i++)for(j=0;j<L->len;j++)if(L->data[j].stock>L->data[j+1].stock){g=L->data[j];L->data[j]=L->data[j+1];L->data[j+1]=g;}	
}

这篇关于数据结构:顺序表的应用--仓库货物管理信息管理系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1134643

相关文章

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

在Node.js中使用.env文件管理环境变量的全过程

《在Node.js中使用.env文件管理环境变量的全过程》Node.js应用程序通常依赖于环境变量来管理敏感信息或配置设置,.env文件已经成为一种流行的本地管理这些变量的方法,本文将探讨.env文件... 目录引言为什么使php用 .env 文件 ?如何在 Node.js 中使用 .env 文件最佳实践引

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

python库pydantic数据验证和设置管理库的用途

《python库pydantic数据验证和设置管理库的用途》pydantic是一个用于数据验证和设置管理的Python库,它主要利用Python类型注解来定义数据模型的结构和验证规则,本文给大家介绍p... 目录主要特点和用途:Field数值验证参数总结pydantic 是一个让你能够 confidentl

JAVA实现亿级千万级数据顺序导出的示例代码

《JAVA实现亿级千万级数据顺序导出的示例代码》本文主要介绍了JAVA实现亿级千万级数据顺序导出的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 前提:主要考虑控制内存占用空间,避免出现同时导出,导致主程序OOM问题。实现思路:A.启用线程池

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版