Java:基于Map实现的频率统计代码

简介:
使用泛型 T 代表所要统计信息的类,应该有效的定义该类的 equals() hasCode()
statistics() 方法进行关键字统计。
getAllKeysStatistics() 方法返回底层的 Map ,即所有的键 - 值对。
getAllKeys() 方法返回所有 key 组成的 Set
getKeyStatistics() 方法返回单个确定 Key 的统计信息。
测试例使用 10000 个随机整型数 (0 9) 来统计它们的产生频率。
package  com.zj.col;

 

import  java.util.HashMap;

import  java.util.Map;

import  java.util.Random;

 

public   class  Statistics<T> {

     private  Map<T, Integer>  m  =  new  HashMap<T, Integer>();

 

     public   void  statistics(T t) {

       Integer freq =  m .get(t);

        m .put(t, freq ==  null  ? 1 : freq + 1);

    }

 

     public   void  getAllKeysStatistics() {

       System. out .println( m );

    }

 

     public   void  getAllKeys() {

       System. out .println( m .keySet());

    }

 

     public   int  getKeyStatistics(T t) {

        return   m .get(t) ==  null  ? 0 :  m .get(t);

 

    }

 

     public   static   void  main(String[] args) {

       Random rand =  new  Random();

       Statistics<Integer> s =  new  Statistics<Integer>();

        for  ( int  i = 0; i < 10000; i++) {

            // Produce a number between 0 and 9:

            int  r = rand.nextInt(10);

           s.statistics(r);

       }

       s.getAllKeysStatistics();

       s.getAllKeys();

       System. out .println( "Key -1:"  + s.getKeyStatistics(-1));

       System. out .println( "Key 0:"  + s.getKeyStatistics(0));

    }

}
结果:
{0=1038, 1=1014, 2=939, 3=987, 4=977, 5=974, 6=1036, 7=974, 8=1075, 9=986}

[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

Key -1:0

Key 0:1038
 
本文转自zhangjunhd51CTO博客,原文链接:http://blog.51cto.com/zhangjunhd/69949,如需转载请自行联系原作者
相关文章
|
8天前
|
Java 测试技术 应用服务中间件
常见 Java 代码缺陷及规避方式(下)
常见 Java 代码缺陷及规避方式(下)
30 0
|
10天前
|
Java
Java中ReentrantLock释放锁代码解析
Java中ReentrantLock释放锁代码解析
25 8
|
13天前
|
前端开发 小程序 Java
uniapp上传图片 前端以及java后端代码实现
uniapp上传图片 前端以及java后端代码实现
28 0
|
14天前
|
设计模式 存储 Java
23种设计模式,享元模式的概念优缺点以及JAVA代码举例
【4月更文挑战第6天】享元模式(Flyweight Pattern)是一种结构型设计模式,旨在通过共享技术有效地支持大量细粒度对象的重用。这个模式在处理大量对象时非常有用,特别是当这些对象中的许多实例实际上可以共享相同的状态时,从而可以减少内存占用,提高程序效率
31 4
|
14天前
|
设计模式 Java 中间件
23种设计模式,适配器模式的概念优缺点以及JAVA代码举例
【4月更文挑战第6天】适配器模式(Adapter Pattern)是一种结构型设计模式,它的主要目标是让原本由于接口不匹配而不能一起工作的类可以一起工作。适配器模式主要有两种形式:类适配器和对象适配器。类适配器模式通过继承来实现适配,而对象适配器模式则通过组合来实现
30 4
|
15天前
|
存储 缓存 算法
优化 Java 后台代码的关键要点
【4月更文挑战第5天】本文探讨了优化 Java 后台代码的关键点,包括选用合适的数据结构与算法、减少不必要的对象创建、利用 Java 8 新特性、并发与多线程处理、数据库和缓存优化、代码分析与性能调优、避免阻塞调用、JVM 调优以及精简第三方库。通过这些方法,开发者可以提高系统性能、降低资源消耗,提升用户体验并减少运营成本。
|
17天前
|
Java 开发工具 流计算
flink最新master代码编译出现Java Runtime Environment 问题
在尝试编译Flink源码时遇到Java运行时环境致命错误:EXCEPTION_ACCESS_VIOLATION。问题出现在JVM.dll+0x88212。使用的是Java 11.0.28和Java HotSpot(TM) 64-Bit Server VM。系统为Windows客户端,没有生成核心dump文件。错误日志保存在hs_err_pid39364.log和replay_pid39364.log。要解决这个问题,建议检查JDK版本兼容性,更新JDK或参照错误报告文件提交Bug至http://bugreport.java.com/bugreport/crash.jsp。
|
18天前
|
Java
使用Java代码打印log日志
使用Java代码打印log日志
73 1
|
18天前
|
设计模式 Java 数据库
Java设计模式精讲:让代码更优雅、更可维护
【4月更文挑战第2天】**设计模式是解决软件设计问题的成熟方案,分为创建型、结构型和行为型。Java中的单例模式确保类仅有一个实例,工厂方法模式让子类决定实例化哪个类。适配器模式则协调不兼容接口间的合作。观察者模式实现了一对多依赖,状态变化时自动通知相关对象。学习和适当应用设计模式能提升代码质量和可维护性,但需避免过度使用。设计模式的掌握源于实践与不断学习。**
Java设计模式精讲:让代码更优雅、更可维护
|
8天前
|
Java
代码的魔法师:Java反射工厂模式详解
代码的魔法师:Java反射工厂模式详解
21 0