09.2Java结合Map对图书管理功能优化-23/04/27

要实现的功能为:根据图书类型进行分组,显示每种图书类型的总数量以及每个类型下具体的商品信息

①按照传统不用map的方法,是用一个数组或者集合存储图书有的几种类型

定义另一个数组或集合存储每种类型有多少个,还要遍历好多次来查找

public static void showType() {
		int numType[] = {};
		List<String> type = new ArrayList<>();
		for(Book i : list) {
			boolean find = false; 
			String arr = i.getType();
			for(int j = 0; j<type.size(); j++) {
				if(arr.equals(type.get(j))) {
					numType[type.indexOf(arr)]++;
					find = true;
				}
			}
			if(!find) {
				type.add(arr);
				numType = Arrays.copyOf(numType, numType.length+1);
				numType[numType.length-1] = 1;
			}
		}
		System.out.println("图书类型有"+type.size()+"种");
		for(int i = 0; i< type.size(); i++) {
			System.out.println(type.get(i)+"的图书有"+numType[i]+"种,信息如下:");
			System.out.println("图书编号\t图书名称\t作者\t人气\t图书类型\t全部(1.表示完结,2.表示连载中)");
			for(Book j : list) {
				if(j.getType().equals(type.get(i))) {
					System.out.println(j.getNum()+"\t"+j.getName()+"\t"+j.getAuthor()+"\t"+j.getTop()+"\t"+j.getType()+"\t"+j.getState());
				}
			}
		}
	}

②用map优化

用map的键存储类型,值存储一个Book类型的List;

由于map的特性,不允许有重复的键,所以直接不管是否重复都可以往里放,再用一个list获取map的值,根据其是否为空决定往map里放的list为新的还是已经有了数据累加新数据的;最后根据map不同键对应的值list的长度获得这种类型有几个元素;

package com.work;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;


import java.util.Set;

public class BookManage {
	static List<Book> list = new ArrayList<>();
	static Map<String, Integer> map = new HashMap<>();
	public static void main(String[] args) {
//		9.根据图书类型进行分组,显示每种图书类型的总数量以及每个类型下具体的商品信息?
		groupByType();
	}
	/**
	 * 9.根据图书类型进行分组,显示每种图书类型的总数量以及每个类型下具体的商品信息?
	 */
	public static void groupByType() {
		Map<String, List<Book>> map = new HashMap<>();
		for(Book book : list) {
			List<Book> list1 = map.get(book.getType());
			if(list1==null) {
				List<Book> list2 = new ArrayList<>();
				list2.add(book);
				map.put(book.getType(), list2);
			}else {
				List<Book> list3 = map.get(book.getType());
				list3.add(book);
				map.put(book.getType(), list3);
			}
		}
		Set<String> set = map.keySet();
		System.out.println("图书共有 "+map.size()+"种类型");
		for(String i : set) {
			System.out.println(i+"类型的书有 "+map.get(i).size()+"本,详细信息如下:");
			System.out.println("图书编号\t图书名称\t作者\t人气\t图书类型\t全部(1.表示完结,2.表示连载中)");
			for(Book j : map.get(i)) {
				System.out.println(j.getNum()+"\t"+j.getName()+"\t"+j.getAuthor()+"\t"+j.getTop()+"\t"+j.getType()+"\t"+j.getState());
			}
		}
	}

	static {
		Book b1 = new Book("10011", "光阴之外", "耳根", 109000, "仙侠", 2);
		Book b2 = new Book("10012", "姑娘请留步", "天蚕土豆", 7162, "玄幻", 2);
		Book b3 = new Book("10013", "太初", "高楼大厦", 68000, "玄幻", 1);
		Book b4 = new Book("10013", "仙宫", "打眼", 210000, "仙侠", 2);
		Book b5 = new Book("10014", "天才相师", "打眼", 80100, "都市", 2);
		Book b6 = new Book("10015", "一念永恒", "耳根", 577000, "仙侠", 2);
		list.add(b1);
		list.add(b2);
		list.add(b3);
		list.add(b4);
		list.add(b5);
		list.add(b6);
	}
}
package com.exam;

public class Book {
	/**图书编号*/
	private String num;
	/**图书名称*/
	private String name;
	/**作者*/
	private String author;
	/**人气*/
	private int top;
	/**图书类型*/
	private String type;
	/**状态*/
	private int state;
	
	public String getNum() {
		return num;
	}
	public void setNum(String num) {
		this.num = num;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public String getAuthor() {
		return author;
	}
	public void setAuthor(String author) {
		this.author = author;
	}
	public int getTop() {
		return top;
	}
	public void setTop(int top) {
		this.top = top;
	}
	public String getType() {
		return type;
	}
	public void setType(String type) {
		this.type = type;
	}
	public int getState() {
		return state;
	}
	public void setState(int state) {
		this.state = state;
	}
	public Book(String num, String name, String author, int top, String type, int state) {
		super();
		this.num = num;
		this.name = name;
		this.author = author;
		this.top = top;
		this.type = type;
		this.state = state;
	}
	
	public Book() {
		
	}
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值