【问题标题】:issue counter and arrays问题计数器和数组
【发布时间】:2014-11-23 23:15:15
【问题描述】:

我正在尝试找到一种方法来使这个字母计数器运行,并且它必须在 letterCounter 类中使用数组。我对如何在简洁的地方做到这一点感到困惑。这是我为这部分给出的说明:

如果 mychar 是小写字母,我们可以在我们的 count 数组中找到对应的位置 简单的减法,像这样: 计数[mychar - 'a'] (a 是另一个神奇的值,你最终会想用一个常数来替换它。) 那么大写字母呢?使用静态方法 Character.toLowerCase(mychar)。 注意: if (Character.toLowerCase(mychar) - 'a') 计算结果超出范围 [0, 25],则 mychar 不是字母表,应忽略。 因此,您之前添加的 process 方法只是遍历传递的 String 中的字符 in,并为每个字母递增数组中的值。 类似地,getCount 方法将字符参数转换为位置并返回 数数。确保您了解(以及稍后记录)此方法在 参数不是字母表。

这是我的代码:

import java.util.Scanner;

public class CounterDemo
{
public static void main(String[] args)
{
    LetterCounter cc = new LetterCounter();
    cc.process("foo");
    cc.process("supercalafrajalisticexpialadoscious");
    cc.process("zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz");

    System.out.println("There are " + cc.getCount('z') + "z's");
}
}

public class LetterCounter {

public int getCount(char letter)
{
   // empty method for now

  return 0;
}

public void process(String string) {
    // TODO Auto-generated method stub

}

}

那么我是否将 0-25 存储在一个数组中并要求返回该数组中的字母?

【问题讨论】:

    标签: java arrays java.util.scanner counter


    【解决方案1】:

    是的,你的解决方案是一个很好的解决方案,所以步骤是:(伪代码)

    LetterCount 类: - 有一个数组计数[25]

    处理函数:

    • 扫描每个字符

    • 如果 char -'a' 不是字母:继续

    • count[char - 'a']++(其实'a'代表97,是ascii值)

    获取计数函数

    • 返回计数[param.tolowercase - 'a']

    【讨论】:

      【解决方案2】:

      这是基本的解决方案...您仍然需要仅过滤 getCount 的结果以获取字母字符,但差不多就是这样

      public class LetterCounter 
      {
        public LetterCounter()
        {
            hash = new int[255];
      
            for (int i = 0; i < hash.length(); i++) hash[i] = 0;
        }
      
        private int[] hash;
      
        public int getCount(char letter)
        {
            return hash[(int)letter)];
        }
      
        public void process(String string) 
        {
            for (int i = 0; i < string.length(); i++)
            {
               hash[(int)string.charAt(i)]++;
            }
        }
      
      }
      

      【讨论】:

        猜你喜欢
        • 2014-10-10
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2021-12-24
        • 1970-01-01
        • 2022-11-13
        • 1970-01-01
        相关资源
        最近更新 更多