一、代码实现

  1. import java.io.*;
  2. import java.util.*;
  3. /**
  4. 功能:统计文件中每个字符出现的次数
  5. 思路:
  6. 1.定义字符读取(缓冲)流
  7. 2.循环读取文件里的字符,用一个String类型变量接收(newValue)
  8. 3.把newValue变成字符数组       char[] ch = newValue.toCharArray();
  9. 4.遍历ch,将ch中所有的字符存入一个Map集合中(TreeSet),键对应字符,值对应字符出现的次数
  10. 5.遍历打印map集合中的键和值,也就是字符出现的次数
  11. **/
  12. public class Stat {
  13. public static void main(String[] args) {
  14. long startTime = System.currentTimeMillis();
  15. stat(new File("e:\\input.txt"));
  16. long endTime = System.currentTimeMillis();
  17. System.out.println("\n运行时间:" + (endTime - startTime) + "毫秒");
  18. }
  19. public static void stat(File file){
  20. BufferedReader bfr = null;                          //定义字符读取(缓冲)流
  21. try{
  22. bfr = new BufferedReader(new FileReader(file)); //给该流赋值
  23. String value = null;                            //定义一个临时接收文件中的字符串变量
  24. String newValue = "";                           //接收文件中所有字符串的变量
  25. while((value = bfr.readLine()) != null){        //开始读取文件中的字符
  26. newValue = newValue + value;                //存入newValue变量中
  27. }
  28. char[] ch = newValue.toCharArray();             //把newValue变成字符数组
  29. TreeMap<Character,Integer> tm = new TreeMap<Character,Integer>(); //定义一个TreeMap,默认从小到大顺序,键对应字符,值对应字符出现的次数
  30. for(int x = 0;x < ch.length; x++){               //遍历ch,将ch中所有的字符存入一个Map集合中(TreeSet),键对应字符,值对应字符出现的次数
  31. char c = ch[x];
  32. if(tm.containsKey(c)){                      //如果TreeMap(tm)中有该键,则取出该键中的值,也就是出现的次数
  33. int count = tm.get(c);
  34. tm.put(c, count + 1);                   //把新值存入tm集合中,如果键相同的话, 新键会替换老键,值也随着变化了
  35. }
  36. else{
  37. tm.put(c, 1);                           //如果没有出现该键就说明是第一次出现,存入1次
  38. }
  39. }
  40. //下面的是取出TreeMap(tm)中的键和值
  41. Set<Map.Entry<Character, Integer>> set = tm.entrySet();
  42. Iterator<Map.Entry<Character, Integer>> iter = set.iterator();
  43. while(iter.hasNext()){
  44. Map.Entry<Character, Integer> map = iter.next();
  45. char k = map.getKey();
  46. int v = map.getValue();
  47. System.out.print(k + "(" + v + "次)  ");
  48. }
  49. }
  50. catch(IOException e){
  51. System.out.println("文件读取错误");
  52. }
  53. finally{
  54. try{
  55. if(bfr!=null)
  56. bfr.close();
  57. }
  58. catch(IOException e){
  59. System.out.println("文件关闭错误");
  60. }
  61. }
  62. }
  63. }

二、测试结果

1 在E:\input.txt中输入两行数据:

Hello World!

您好世界!

运行结果为:

(1次) !(1次) H(1次) W(1次) d(1次) e(1次) l(3次) o(2次) r(1次) 世(1次) 好(1次) 您(1次) 界(1次) !(1次) ,(1次)

运行时间:1毫秒

注:上面第1个没显示出来的字符是空格。

2 在E:\inut.txt中多放些数据,比如放了1.2M的数据,运行时间是3秒。

这里可以看出,这个算法仅仅是实现了最基本需求,当文件很大时,需要很长的时间才能得出结果。如果是在真实项目里,需要提高此算法的效率,或改用其它思路来实现。

Java笔记13:统计文件中每个字符出现的次数的更多相关文章

  1. Java基础知识强化之集合框架笔记61:Map集合之统计字符串中每个字符出现的次数的案例

    1. 首先我们看看统计字符串中每个字符出现的次数的案例图解: 2. 代码实现: (1)需求 :"aababcabcdabcde",获取字符串中每一个字母出现的次数要求结果:a(5) ...

  2. 统计一个文件中出现字符'a'的次数

    # -*- coding: utf-8 -*- #python 27 #xiaodeng #统计一个文件中出现字符'a'的次数 #http://www.cnblogs.com/hongten/p/ho ...

  3. 使用Map,统计字符串中每个字符出现的次数

    package seday13; import java.util.HashMap; import java.util.Map; /** * @author xingsir * 统计字符串中每个字符出 ...

  4. 统计字符串中每个字符出现的次数(Python)

    #统计字符串中每个字符出现的次数 以The quick brown fox jumps over the lazy dog为例 message='The quick brown fox jumps o ...

  5. Java 13天基础 06天map集合小练习(黑马程序员) 统计字符串中每个字符出现的次数 (经典面试题)

    import java.util.HashMap; import java.util.Map; import java.util.Scanner; /** * 目标 : 输出一个字符串中每个字符出现的 ...

  6. Java中统计字符串中各个字符出现的次数

    import java.util.Iterator; import java.util.Set; import java.util.TreeMap; public class TreeMapDemo ...

  7. linux命令统计文件中某个字符串出现的次数

    1.使用grep linux grep命令在我的随笔linux分类里有过简单的介绍,这里就只简单的介绍下使用grep命令统计某个文件这某个字符串出现的次数,首先介绍grep命令的几个参数,详细参数请自 ...

  8. javascript 统计字符串中每个字符出现的次数

    var str = "abdcadfasfdbadfafdasdfasyweroweurowqrewqrwqrebwqrewqrejwq;;"; // console.log(nu ...

  9. 使用grep查找文件中指定字符出现的次数

    grep -o ‘好' 文件名.txt | wc -l -o 指示grep显示所有匹配的地方,并且每一个匹配单独一行输出.这样只要统计输出的行数就可以知道这个字符出现的次数了.

随机推荐

  1. Java学习笔记(七)——获取类中方法的信息,java的LinkedList

    [前面的话] 在实际项目中学习知识总是最快和最有效的,既能够较好的掌握知识,又能够做出点东西,还是简单的知识总结,最近一直在总结笔记,写的东西还是比较水,希望慢慢可以写出一些干货. 学习过程中的小知识 ...

  2. Vue.js—组件快速入门及Vue路由实例应用

    上次我们学习了Vue.js的基础,并且通过综合的小实例进一步的熟悉了Vue.js的基础应用.今天我们就继续讲讲Vue.js的组件,更加深入的了解Vue,js的使用.首先我们先了解一下什么是Vue.js ...

  3. pc、移动端H5网站 QQ在线客服、群链接代码【我和qq客服的那些事儿】

    转载:http://blog.csdn.net/fungleo/article/details/51835368#comments 移动端H5 QQ在线客服链接代码 <a href=" ...

  4. 解决CentOS7.4KDE桌面或者gnome桌面安装VLC及声音问题

    一.安装VLC 1.下载源 https://mirrors.tuna.tsinghua.edu.cn/epel/7/x86_64/e/epel-release-7-11.noarch.rpm http ...

  5. 山东BOSS性能压力测试

    1. 概述 在山东BOSS性能压力测试过程中,发现脚本对于整个压力测试过程的重要性,一个压力测试脚本录制和编辑修改得怎么样直接影响后面压力测试的执行.通常情况下,脚本应尽可能的精简,就像写代码一样.针 ...

  6. 三:Ionic Framework开发Android应用

    第一步:添加Android平台 ionic cordova platform add android 第二步:编译Android应用 中间等待的过程有点长,需要耐心等待,生成的apk此时可以复制至平板 ...

  7. linux 把用户加入一个组&从这个组中移除

    # usermod -a -G www zhou // zhou这个用户现在属于两个组 zhou www # groups zhou zhou : zhou www # gpasswd -d zhou ...

  8. HDU 6467.简单数学题-数学题 (“字节跳动-文远知行杯”广东工业大学第十四届程序设计竞赛)

    简单数学题 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Submi ...

  9. 删除元素(LintCode)

    删除元素 给定一个数组和一个值,在原地删除与值相同的数字,返回新数组的长度. 元素的顺序可以改变,并且对新的数组不会有影响. 样例 给出一个数组 [0,4,4,0,0,2,4,4],和值 4 返回 4 ...

  10. (转) HA的几种方案

    数据库HA   一般把数据库层面的HA,和应用层面HA分开考虑 数据库一般采用数据库产品提供的HA方案,比如Oracle的RAC,mysql的集群,mongodb的replica set等 无HA的运 ...