码迷,mamicode.com
首页 > 编程语言 > 详细

Java 字符串计算频率出现最高的字符

时间:2015-06-09 20:07:17      阅读:176      评论:0      收藏:0      [点我收藏+]

标签:

public class HighFrequencyWord {
public static void findFrequencyWord(String str) { 
        Collection<Integer> al=new ArrayList<Integer>(); 
        Map<String,Integer> map=new HashMap<String,Integer>(); 
        String tempStr = str; 
        String[] stringArray = str.split(""); 
        
        System.out.println(" stringArray.length = "+stringArray.length);
        
        //用来存储字符串里每个出现过的字符,且不会出现重复的 
        Set<String> set = new HashSet<String>(); 
        int stringLength = stringArray.length; 
        for (int i = 0; i < stringLength; i++) { 
            set.add(stringArray[i]); 
        } 
        //移掉set中的一个空字符 
        set.remove(""); 
         
        System.out.println(set); 
        int count = 0; 
        boolean flag = true; 
         
        for (String s : set) { 
             
            while (flag) { 
                //如果索引存在 
                if (tempStr.indexOf(s) != -1) { 
                    //记录出现字符的当前位置 
                    int index = tempStr.indexOf(s); 
                    //让字符串从下一索引处开始 
                    tempStr = tempStr.substring(index+1); 
                    //如果索引存在,记录值加1 
                    count++; 
                     
                } else { 
                    //如果索引不存在,赋值false退出循环 
                    flag = false; 
                } 
                 
            } 
            //为了执行下一循环 
            flag = true; 
            //把值存入map,让字符与其频率对应 
            map.put(s,count); 
            //因为是上一结果,所以让值归零,并且字符串变回原来的字符串 
            count = 0; 
            tempStr = str; 
             
        } 
        //将map的值变为一个列表 
        al= map.values(); 
        
        //然后转为数组 
        Integer[] stringCount =al.toArray(new Integer[]{}); 
        int countLength=stringCount.length; 
        //按升序排序 
        Arrays.sort(stringCount); 
        //得到数组最大值 
        int max=stringCount[countLength-1]; 
        for(String s: set){ 
            for(int i=0;i<countLength;i++){ 
                //如果map的值与最大值相同,则输出 
                if(map.get(s)==max){ 
                    System.out.println(s + ":" + max); 
                } 
            } 
             
        } 
    } 
     
    public static void main(String[] args) { 
        findFrequencyWord("ababbsssss"); 
    } 

Java 字符串计算频率出现最高的字符

标签:

原文地址:http://blog.csdn.net/luo446718254/article/details/46429909

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!