Java:组合数组中的计数以获得百分比

时间:2012-04-08 23:45:07

标签: java

我正在编写一个读取给定文件的频率计数器,返回文件中每个字母的频率(以百分比表示)。到目前为止,我的代码读取文件并列出文件中出现的每个字母的计数。我无法弄清楚如何组合所有计数以产生百分比。下面是我的代码,如果我没有正确使用代码块,请原谅。还在学习所有这些东西。

import java.io.File;
import java.util.*;

public class FrequencyCounter
{

    public static void main(String[] args )
    {
        char[] capital = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J','K', 'L', 'M', 'N',
                'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'};

        char[] small =   { 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',
                'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z' };

        Scanner scan;
        try 
        {
            scan = new Scanner(new File("c://Users//Mikel//Desktop//School Work//CIS407//Week1//mary.txt"));
        } 

        catch (Exception e) 
        {
            System.out.println("File not found");
            return;
        }

        int[] count = new int[26];



        while(scan.hasNextLine()) 
        {
            String line = scan.nextLine();
            System.out.println("Line read: " + line);
            char[] digit = line.toCharArray();


            for(int i = 0; i < digit.length; i++) 
            {
                for(int j = 0; j < 26; j++) 
                {
                    if(digit[i] == capital[j] || digit[i] == small[j]) 
                    {
                        count[j]++;
                        break;
                    }
                }
            }
        }


        for (int i = 0; i < 26; i++)
        {
            System.out.print("  " + capital[i]);
            System.out.println("          " + (count[i]));

        }

    }
}

2 个答案:

答案 0 :(得分:1)

通过观察ch - 'a'是返回小写字母索引的整数表达式,您的代码可以大大简化,ch - 'A'对大写字母执行相同的操作。因此嵌套循环以及大小写的数组都不是必需的。您可以通过调用Char.isUpperCase(ch)Char.isLowerCase(ch)来判断字符是大写还是小写。

您可以通过将所有计数加起来并按常规方式计算百分比来获得百分比:

double pct = (count[i]*100.0) / total;

答案 1 :(得分:0)

有很多方法可以做到这一点。正如您所指出的,下一步是提出总数。这意味着循环遍历两个数组并将总数存储在单独的变量中。从那里你可以将每个计数除以总数来得到一个百分比。

换句话说,您还需要两个循环才能完成任务。

您也可以考虑将代码分解为方法。每个循环说一个,所以它更像是:

countLetters();
calculateTotal();
printPercentages();

此外,您可以使代码更简单。你可以调用Character.toLowerCase(digit [i])来获得小写的一个[所以你只需要处理一个],而不是从0循环到25并检查它是否相等。然后你可以从你的字母中减去 - 'a'来获得索引,而不使用26个字符的数组。