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

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

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

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

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

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

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

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

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

 

#include<stdio.h>
#include<windows.h>
#include<stdlib.h>
#define MAXSIZE 100

typedef 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;
			}	
}