自动售货机 (30分)

在这里插入图片描述

#include<stdio.h>
int main(void)
{
  char a[10][20] = {"Table-water","Table-water","Table-water","Coca-Cola","Milk","Beer","Orange-Juice","Sprite","Oolong-Tea","Green-Tea"};
  int b[11] = {0,0,0,0,0,0,0,0,0,0,0};
  int c[50];
  int i=1, k, sum = 0, money, SUM = 0, change, flag=0;
  
  scanf("%d",&money);//输入币值并计算总币值
  while((money!=-1)&&(money <= 10))
  {
    sum = sum + money;
    scanf("%d",&money);
  }
  
  scanf("%d",&c[i]);
  while(c[i]!=-1)//将选的货物编号存储到数组c中并计算找零
  {
    switch(c[i])
    {
      case 1: case 2: case 3: SUM = SUM + 1;break;
      case 4: case 5: SUM = SUM + 2;break;
      case 6: case 7: case 8: SUM = SUM + 3;break;
      case 9: case 10: SUM = SUM + 4;break;
      default:break;
    }
    if(SUM>sum)
    {
      printf("Insufficient money");
      flag = 1;
      break;
    }
    i++;
    scanf("%d",&c[i]);
  }
  change = sum-SUM;
  
  //用数组b统计各种商品数量
  i = 1;
  while(c[i]!=-1)
  {
    switch(c[i])
    {
      case 1: b[1]++;break;
      case 2: b[2]++;break;
      case 3: b[3]++;break;
      case 4: b[4]++;break;
      case 5: b[5]++;break;
      case 6: b[6]++;break;
      case 7: b[7]++;break;
      case 8: b[8]++;break;
      case 9: b[9]++;break;
      case 10: b[10]++;break;
      default:break;
    }
    i++;
  }
  
  //输出结果
  if(flag==0)
  {
    printf("Total:%dyuan,change:%dyuan\n",sum, change);
    for(i=1; i<=10; i++)
    {
      if(b[i]==0)
        continue;
      else
      {
        printf("%s:%d;",a[i-1],b[i]);
      }
    }
  }
  
  return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值