购物车(java集合框架应用)
来源:互联网 发布:java poi maven 编辑:程序博客网 时间:2024/05/18 13:23
购物车
Problem Description
各位亲爱的小伙伴们,大家好!
欢迎来到美美自助购物商场,首先请您帮忙建立商品信息,然后选购商品、确定数量,计算出总价格到结算中心进行结算。美美祝您购物愉快噢!
首先读取N行商品信息,每行包含:商品编号、商品名称、生产商、商品价格、库存数量;
接着输入M行购买信息:商品编号、商品数量、购买标志。
输出购物车中的商品数量T,以及T种商品的详细信息(商品编号、商品名称、生产商、商品价格、库存数量)、实际购买数量和购物车商品总价格(保留2位小数)。
美美商场友情提示:商品数量充分时,您才能购买;另外,您购物成功后,一定要记得增减商品库存数量噢!
Input
首行是商品种类的数量N;
接下来是N行的商品信息,每行商品信息为:商品编号、商品名称、生产商、商品价格、库存数量;
购物操作的次数M;
接下来是M行的商品购买操作的信息,每行购买信息为:商品编号、购买数量count(count>0)、购买标志(1--购买,购物车中该商品数量增加;2--退货,购物车中该商品数量减少,3-删除商品,删除操作时count列的值无效)。
Output
购物车中商品的数量T;
购物车中的所有商品详情,每种商品详情占一行,中间数据用1个空格符隔开。商品详情包括:商品编号、商品名称、生产商、商品价格、商品最新库存数量、已购买的商品数量。(商品价格保留2位小数),按照商品编号从小到大的顺序进行输出。若T=0,则无商品详情信息输出。
最后一行输出购物车中商品的总价格。(保留2位小数)
Example Input
51 运动鞋 Adidas 300.80 102 蓝球服 李宁 268.00 103 苹果 栖霞 5.00 5004 智能手表 苹果 4888.00 105 鼠标 罗技 120.00 5091 5 13 5 14 1 13 2 25 2 1 1 2 15 0 33 1 13 5 2
Example Output
21 运动鞋 Adidas 300.80 3 74 智能手表 苹果 4888.00 9 16993.60
Hint
1、购买商品的实际数量要小于或等于库存数量,退货时的数量要小于购物车中该商品的现有数量。
2、购买行为发生时,注意库存的变化。购买商品之后减库存,退货之后加库存。
3、购物车中某商品的实际数量为0时,就移除它。
Author
import java.text.ParseException;import java.text.SimpleDateFormat;import java.util.*;class Goods { int id; String name; String namewhere; double price; int num; int snum; public Goods(){ } public Goods(int id,String name,String namewhere,double price,int num,int snum) { this.id = id; this.name = name; this.namewhere = namewhere; this.price = price; this.num = num; this.snum = snum; } Map<Integer,Goods>l ; public void init() { l = new TreeMap<Integer,Goods>(); } public void foreach() { int k = 0; for(Goods goods:l.values()) { if(goods.snum>0) k++; } System.out.println(k); double s = 0; for (Goods goods : l.values()) { if (goods.snum > 0) { System.out.print(goods.id + " " + goods.name + " "+ goods.namewhere + " "); System.out.printf("%.2f ", goods.price); System.out.println(goods.num + " " + goods.snum); s = s + goods.price * goods.snum; } } System.out.printf("%.2f\n", s); }}public class Main{ public static void main(String[] args) throws ParseException { Scanner input = new Scanner(System.in); Goods ls = new Goods(); ls.init(); int n = input.nextInt(); for(int i=0;i<n;i++) { int id = input.nextInt(); String name = input.next(); String namewhere = input.next(); double price = input.nextDouble(); int num = input.nextInt(); int snum = 0; Goods goods1 = new Goods(id, name, namewhere, price, num, snum); ls.l.put(id, goods1); } int m = input.nextInt(); for(int i=0;i<m;i++) { int buyid = input.nextInt(); int buynum = input.nextInt(); int buyflag = input.nextInt(); Goods good = ls.l.get(buyid); if(buyflag==1) { if(buynum>good.num){ good.snum = good.num+good.snum; good.num = 0; ls.l.put(buyid,good); } else{ good.snum = good.snum+buynum; good.num = good.num-buynum; ls.l.put(buyid,good); } } else if(buyflag==2){ if(buynum>good.snum){ good.num = good.num + good.snum; good.snum = 0; ls.l.put(buyid,good); } else{ good.num = good.num+buynum; good.snum = good.snum-buynum; ls.l.put(buyid,good); } } else if(buyflag==3) { good.num = good.snum+good.num; good.snum = 0; ls.l.put(buyid,good); } } ls.foreach(); } }
- 购物车(java集合框架应用)
- 购物车(Java集合框架)
- Java集合框架应用
- java练习--集合-List书店购物车
- 深入剖析Java集合框架及其显示应用(上)
- 黑马程序员—java集合框架应用
- java集合框架 arrayblockingqueue应用分析
- Java集合(一)---Java集合框架
- Map集合实现的纯java购物车
- java集合框架(map集合)
- Java基础--集合框架(Map集合)
- java集合框架(1、集合介绍)
- PHP 购物车 session(非框架)
- PHP 购物车 session(非框架)
- Java集合:集合框架
- yii框架购物车
- 购物车的框架
- Java集合框架(转)
- Ubuntu 14.04 64位下Matlab 2015的安装
- binder通信实例之java客户端与c++服务端
- Hibernate小结(1)
- 最短路的四种算法总结
- 动态规划―公共子序列
- 购物车(java集合框架应用)
- binder通信实例之c++客户端与c++服务端
- Android中远程Service和Activity交互
- Httpservlet cannot be resolved to a type的原因与解决方法
- DAY 2 HTML作诗
- virtualenv
- systemctl命令
- Machine Learning in Action_CH2_1_kNN
- 最大和子矩阵