HashMap_经典存储_经典分拣思路

news/2024/7/4 15:42:38

Collection的概念
Collection表示一组对象,它是集中,收集的意思,就是把一些数据收集起来
Collection函数库是在java.util包下的一些接口和类,类是用来产生对象存放数据用的,而接口是访问数据的方式
Collection函数库与数组的两点不同:
1.数组的容量是有限制的,而Collection库没有这样的限制,它容量可以自动的调节
2.Collection函数库只能用来存放对象,而数组没有这样的限制
Collection接口是Collection层次结构中根接口,它定义了一些最基本的访问方法,让我们能用统一的方式通过它或它的子接口来访问数据
区别:Collection代表一组对象,Collection函数库就是Java集合框架,Collection接口,是这个集合框架中的根接口
存放在Collection库中的数据,被称为元素

                               Collection
                                   |
                               |      |
 set(无序、不可重复) List(有序、可重复) Map(key/Value键值对)
 |                                  |
 HashSet                          HashMap

 Collection接口:定义了存取一组对象的方法,其子接口Set和List分别定义了存储方式
 Set中的数据对象没有顺序且不可以重复
 List中的数据对象有顺序且可以重复
 Map接口定义了存储"键(key)-值(value)映射对"的方法
 接口中定义了一些规范,规范就是一些不变的东西,接口中定义了规范,实现类一定要实现

1. HashMap_经典存储_经典分拣思路

TestHashMap3.java

package junit.matrix.map;

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

/**
 * 简单的加入面向对象
 * 
 * TestHashMap2<BR>
 * 创建人:Matrix <BR>
 * 时间:2016年2月3日-下午8:23:00 <BR>
 * 
 * @version 1.0.0
 *
 */
public class TestHashMap3 {

    /**
     * 定义一个Student类,属性:name/姓名:no/班号,score/成绩
     * 
     * 现在将若干Student对象放入List,请统计每个班级的总分和平均分
     * 
     * 面向对象分拣存储
     * 
     * 不推荐使用Map<String,List<Student>>操作不方便 推荐使用Map<String,ClassRoom>
     * 
     * 思路:简单封装一个班级类即可
     * 
     * 方案:面向对象+分解存储
     * 
     */

    public static void main(String[] args) {
        // 1、考试
        List<Student> stuList = exam();
        // 2、分析成绩
        Map<String, ClassRoom> map = count(stuList);
        // 3、查看成绩(总分/平均分)
        view(map);
    }

    /**
     * 第三步:总看每个班的总分和平均分
     */
    public static void view(Map<String, ClassRoom> map) {
        Set<String> keys = map.keySet();
        // 获取迭代器对象
        Iterator<String> keysIt = keys.iterator();
        // 先判断
        while (keysIt.hasNext()) {
            // 再获取
            String no = keysIt.next();
            ClassRoom room = map.get(no);
            // 查看总分 计算平均分
            double total = room.getTotal();
            double avg = total / room.getStuList().size();
            // System.out.println(room.getStuList().size());
            System.out.println("班级:" + no + "----------->总分:" + total + "------------------>平均分:" + avg);
        }
    }

    /**
     * 第二步:对数据进行统计分析 1、面向对象 2、分拣存储
     */
    public static Map<String, ClassRoom> count(List<Student> list) {
        Map<String, ClassRoom> map = new HashMap<String, ClassRoom>();
        // 1、遍历list
        for (Student stu : list) {
            // 2、分拣存储
            // 查看是否存在该编号的班级,如果不存在则创建班级,如果存在则存放学生统计总分
            // 班级编号
            String no = stu.getNo();
            // 分数
            double score = stu.getScore();
            // 班级如果不存在则创建班级
            ClassRoom room = map.get(stu.getNo());
            if (null == room) {
                room = new ClassRoom(no);
                map.put(no, room);
            }
            // 如果班级存在,放入学生
            room.getStuList().add(stu);
            // 计算总分
            room.setTotal(room.getTotal() + score);
        }
        return map;
    }

    /**
     * 第一步:模拟考试 测试数据 到List中
     */
    public static List<Student> exam() {
        // 将学生成绩放置到list里面
        List<Student> list = new ArrayList<Student>();
        // 存放学生成绩
        list.add(new Student("老裴", "A班", 80));
        list.add(new Student("Matrix", "A班", 90));
        list.add(new Student("dick", "A班", 98));
        list.add(new Student("keke", "A班", 50));
        list.add(new Student("mini", "A班", 78));
        list.add(new Student("Array", "B班", 65));
        list.add(new Student("Ada", "B班", 33));
        list.add(new Student("vickey", "B班", 88));
        list.add(new Student("Tom", "B班", 93));
        // System.out.println(list.size());
        return list;
    }

}
 

ujP4aoL.png
plX2xQO.png

转载于:https://www.cnblogs.com/SparseMatrix/p/5210835.html


http://www.niftyadmin.cn/n/4610656.html

相关文章

isELIgnored=false

<% page isELIgnored"false"%>的作用 JSP 2.0的一个主要特点是它支持表达语言(expression language)。 JSTL表达式语言可以使用标记格式方便地访问JSP的隐含对象和JavaBeans组件&#xff0c;JSTL的核心标记提供了流程和循环控制功能。自制标记也有自定义函数…

Spring配置文件been中配置property标签的name和ref的区别

这里的<property>中name和ref虽然是同名的但是&#xff0c;<property> 中name是指LoginService类中的参数; ref是当前xml文件中叫做这个名字的bean&#xff0c;把它当作参数传进LoginService中

sql 注入攻防

为什么80%的码农都做不了架构师&#xff1f;>>> SQL注入攻防入门详解 安全性篇目录 毕业开始从事winfrm到今年转到 web &#xff0c;在码农届已经足足混了快接近3年了&#xff0c;但是对安全方面的知识依旧薄弱&#xff0c;事实上是没机会接触相关开发……必须的各…

ActionContext.getContext().getSession() 和 HttpSession session = ctx.getSession(); 中session的区别

① Map session ServletActionContext.getContext().getSession(); ② ActionContext.getContext().getSession(); ③ WebContext ctx WebContextFactory.get(); HttpSession session ctx.getSession(); ① 获取的session是原生的session…

进阶学习js中的执行上下文

在js中的执行上下文&#xff0c;菜鸟入门基础 这篇文章中我们简单的讲解了js中的上下文&#xff0c;今天我们就更进一步的讲解js中的执行上下文。 1、当遇到变量名和函数名相同的问题。 var a 10; function a(){console.log(1); } a(); //报错 如果你觉得函数a会覆盖变量a那你…

Docker中Tomcat容器访问出现404

1. 在后台创建一个tomcat容器,设置端口号为8899 2. 访问为404 3. 进入这容器&#xff0c;发现webapps下面为空 4. 将webapps.dist 下的东西拷到webapps 5. 访问成功

CentOS 6.5编译安装Nginx+MySQL+PHP

一、配置防火墙&#xff0c;开启80端口、3306端口&#xff0c;关闭SELINUX[rootZabbix ~]# vim /etc/sysconfig/iptables -A INPUT -i lo -j ACCEPT -A INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT -A INPUT -m state --state NEW -m tcp -p tcp --dport 8…

L'Hospital法则及其应用

from: http://math.fudan.edu.cn/gdsx/XXYD.HTM