0

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

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]));

        }

    }
}
4

2 回答 2

1

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

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

double pct = (count[i]*100.0) / total;
于 2012-04-08T23:50:35.107 回答
0

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

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

您也可以考虑将代码分解为方法。每个循环说一个,这样它看起来更像:

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

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

于 2012-04-08T23:48:09.643 回答