首页 > 编程语言 >Java 集合中的组内平均值计算

Java 集合中的组内平均值计算

时间:2024-06-01 13:34:03浏览次数:33  
标签:Java 平均值 组内 score 分组 Student new public name

在Java开发中,集合(Collection)是一个重要的数据结构,广泛应用于各种场景。计算集合中的组内平均值是一个常见的操作,尤其是在数据分析、统计和处理时更为重要。本文将深入探讨如何使用Java来计算集合中的组内平均值,涵盖基本概念、具体实现、优化策略和实用示例。

集合框架概述

Java集合框架(Java Collections Framework,简称JCF)提供了一组接口和类,用于存储和操作数据。常见的集合接口包括:

  • ​List​​:有序集合,允许重复元素。
  • ​Set​​:无序集合,不允许重复元素。
  • ​Map​​:键值对集合,键不允许重复。

这些集合接口的实现类如​​ArrayList​​​、​​HashSet​​​和​​HashMap​​等,提供了不同的性能特征和使用场景。

计算集合的组内平均值

计算集合中的组内平均值涉及以下几个步骤:

  1. 数据分组:根据某一条件将集合元素分组。
  2. 计算平均值:对于每一组,计算其平均值。

我们将通过实例代码进行详细讲解。

实例代码实现

假设我们有一个​​Student​​类,包含学生的名字和成绩。我们希望根据成绩分组,并计算每个分组的平均成绩。

import java.util.*;
import java.util.stream.Collectors;

class Student {
    String name;
    double score;

    public Student(String name, double score) {
        this.name = name;
        this.score = score;
    }

    public String getName() {
        return name;
    }

    public double getScore() {
        return score;
    }
}

public class GroupAverageExample {
    public static void main(String[] args) {
        List<Student> students = Arrays.asList(
            new Student("Alice", 85),
            new Student("Bob", 90),
            new Student("Charlie", 85),
            new Student("David", 70),
            new Student("Eve", 70)
        );

        // 分组
        Map<Double, List<Student>> groupedByScore = students.stream()
            .collect(Collectors.groupingBy(Student::getScore));

        // 计算平均值
        Map<Double, Double> averageByGroup = new HashMap<>();
        for (Map.Entry<Double, List<Student>> entry : groupedByScore.entrySet()) {
            double average = entry.getValue().stream()
                .mapToDouble(Student::getScore)
                .average()
                .orElse(0.0);
            averageByGroup.put(entry.getKey(), average);
        }

        // 输出结果
        averageByGroup.forEach((score, avg) -> {
            System.out.println("Score Group: " + score + ", Average: " + avg);
        });
    }
}
代码详解
  1. 创建Student类: ​​Student​​​类包含两个字段:​​name​​​(学生名字)和​​score​​(成绩),并提供相应的构造函数和获取方法。
  2. 初始化学生列表: 使用​​Arrays.asList​​​创建一个包含若干​​Student​​对象的列表。
  3. 分组操作: 使用Java 8的​​stream()​​​和​​Collectors.groupingBy​​​方法,根据成绩将学生分组。​​groupingBy​​​方法将学生按成绩分组,并返回一个​​Map​​,键是成绩,值是该成绩对应的学生列表。
  4. 计算组内平均值: 遍历分组后的​​Map​​​,对于每个分组,使用​​mapToDouble​​​和​​average​​​方法计算平均值。将结果存入一个新的​​Map​​中,键是成绩组,值是该组的平均成绩。
  5. 输出结果: 使用​​forEach​​方法输出每个分组的平均成绩。
优化与扩展
1. 使用​​Collectors.averagingDouble​

上述实现中,我们手动计算了每组的平均值。实际上,Java 8提供了更简洁的方式来计算平均值,即使用​​Collectors.averagingDouble​​。

import java.util.*;
import java.util.stream.Collectors;

class Student {
    String name;
    double score;

    public Student(String name, double score) {
        this.name = name;
        this.score = score;
    }

    public String getName() {
        return name;
    }

    public double getScore() {
        return score;
    }
}

public class GroupAverageExample {
    public static void main(String[] args) {
        List<Student> students = Arrays.asList(
            new Student("Alice", 85),
            new Student("Bob", 90),
            new Student("Charlie", 85),
            new Student("David", 70),
            new Student("Eve", 70)
        );

        // 分组并计算平均值
        Map<Double, Double> averageByGroup = students.stream()
            .collect(Collectors.groupingBy(
                Student::getScore,
                Collectors.averagingDouble(Student::getScore)
            ));

        // 输出结果
        averageByGroup.forEach((score, avg) -> {
            System.out.println("Score Group: " + score + ", Average: " + avg);
        });
    }
}
2. 按条件分组

有时我们可能需要根据更复杂的条件进行分组,例如根据成绩范围(如60-70分、71-80分等)分组。这可以通过自定义分组函数实现。

import java.util.*;
import java.util.stream.Collectors;

class Student {
    String name;
    double score;

    public Student(String name, double score) {
        this.name = name;
        this.score = score;
    }

    public String getName() {
        return name;
    }

    public double getScore() {
        return score;
    }
}

public class GroupAverageExample {
    public static void main(String[] args) {
        List<Student> students = Arrays.asList(
            new Student("Alice", 85),
            new Student("Bob", 90),
            new Student("Charlie", 85),
            new Student("David", 70),
            new Student("Eve", 70)
        );

        // 自定义分组函数
        Map<String, List<Student>> groupedByRange = students.stream()
            .collect(Collectors.groupingBy(student -> {
                if (student.getScore() >= 60 && student.getScore() <= 70) {
                    return "60-70";
                } else if (student.getScore() > 70 && student.getScore() <= 80) {
                    return "71-80";
                } else if (student.getScore() > 80 && student.getScore() <= 90) {
                    return "81-90";
                } else {
                    return "91-100";
                }
            }));

        // 计算平均值
        Map<String, Double> averageByRange = new HashMap<>();
        for (Map.Entry<String, List<Student>> entry : groupedByRange.entrySet()) {
            double average = entry.getValue().stream()
                .mapToDouble(Student::getScore)
                .average()
                .orElse(0.0);
            averageByRange.put(entry.getKey(), average);
        }

        // 输出结果
        averageByRange.forEach((range, avg) -> {
            System.out.println("Score Range: " + range + ", Average: " + avg);
        });
    }
}
性能考虑

在处理大规模数据时,计算平均值的性能非常重要。以下是一些优化建议:

  1. 使用并行流:在数据量较大时,可以使用并行流(parallel stream)来提高性能。
Map<Double, Double> averageByGroup = students.parallelStream()
    .collect(Collectors.groupingBy(
        Student::getScore,
        Collectors.averagingDouble(Student::getScore)
    ));
  1. 减少不必要的计算:确保每个学生对象只进行一次分组和计算,避免重复操作。
  2. 适当的数据结构:根据具体场景选择合适的数据结构,如​​ConcurrentHashMap​​​在并发情况下的表现优于​​HashMap​​。
结论

本文详细介绍了如何在Java中计算集合的组内平均值,包括基本概念、具体实现、优化策略和实用示例。通过使用Java 8的流(Stream)和集合框架,我们可以高效、简洁地完成分组和平均值计算。希望本文对你在实际开发中有所帮助。

参考文献
  1. ​Java Collections Framework​
  2. ​Java Streams API​
  3. ​Effective Java by Joshua Bloch​

标签:Java,平均值,组内,score,分组,Student,new,public,name
From: https://blog.csdn.net/u010986241/article/details/139371936

相关文章

  • Elasticsearch8.4安装及Java Api Client的使用
    目录简介一、ElasticSearch安装二、可视化界面(elasticserach-head)插件安装三、Kibana的安装四、ES核心概念五、IK分词器六、Rest风格说明:ES推荐使用的七、关于索引的操作1、PUT命令2、GET命令3、POST命令4、DELETE命令八、关于文档的操作九、整合SpringBoot,基于......
  • Kafka安装配置及Java中的使用
    目录一、消息队列二、流派分类:三、Kafka基本介绍四、主题和分区的概念五、Kafka集群六、kafka-clients之生产者七、kafka-clients之消费者八、SpringBoot使用Kafka九、Kafka集群中的controller、rebalance、HW(1)controller(2)rebalance机制(3)HW和LEO十、Kafka问题优化......
  • 【JavaScript脚本宇宙】从i18next到Date-fns:国际化和本地化库
    跨越JavaScript新境界:六大库全面评测前言本文将详细介绍六种具有不同功能的JavaScript库,包括处理多语言支持、全球化和本地化、格式化日期、数字和字符串,解析、验证、操作、显示日期和时间,格式化和操作数字,以及最全面、最简单和一致的工具集用于处理JavaScript中的日期等......
  • HTML期末学生大作业-基于班级校园我的校园网页设计与实现html+css+javascript
    ......
  • HTML期末作业-基于HTML+CSS+JavaScript制作学生信息管理系统模板
    ......
  • 1940java swing零售库存管理系统myeclipse开发Mysql数据库CS结构java编程
    一、源码特点   javaswing零售库存管理系统是一套完善的窗体设计系统,对理解SWINGjava编程开发语言有帮助,系统具有完整的源代码和数据库,,系统主要采用C/S模式开发。应用技术:java+mysql开发工具:Myeclipse8.5、jdk。java零售商品库存管理系统二、功能介绍零售库......
  • 1882java密室逃脱管理系统 Myeclipse开发mysql数据库web结构java编程计算机网页项目
    一、源码特点java密室逃脱管理系统是一套完善的web设计系统,对理解JSPjava编程开发语言有帮助采用了java设计,系统具有完整的源代码和数据库,系统采用web模式,系统主要采用B/S模式开发。开发环境为TOMCAT7.0,Myeclipse8.5开发,数据库为Mysql,使用java语言开发。二、功能介绍(1)......
  • 零基础学Java第二十七天之前端-HTML5详解
    前端-HTML5详解一、概述HTML5是HTML的第五个版本,它对HTML进行了许多改进和扩展,使得网页开发更加丰富和便利。HTML5是Web标准的重要组成部分,旨在提高浏览器兼容性,统一网页开发标准。HTML5不仅包括了HTML的基本元素和标签,还新增了许多功能和API,为网页开发提供了更多的可能......
  • 零基础学Java第二十七天之前端HTML5新特性
    HTML5新特性定义文档类型在文件的开头总是会有一个标签语言HTML4,文档声明<!DOCTYPEHTMLPUBLIC"-//W3C//DTDHTML4.01//EN""http://www.w3.org/TR/html4/strict.dtd">语言HTML5,文档声明<!DOCTYPEhtml>新增语义化标签头部标签<header>导航标签<nav>内容标......
  • 零基础学Java第二十四天之注解的理解与使用
    注解1、什么是注解java.annotation包Annotation是从JDK1.5开始引入的新技术,注解即可以对程序员解释又可以对程序解释2、注解与注释的区别注释:对程序员解释代码信息注解:对程序和程序员解释代码信息3、注解的所用不是程序本身,可以对程序作出解释(与注释(comment)类......