RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 738289
Accepted
YuriiS
YuriiS
Asked:2020-10-31 18:42:56 +0000 UTC2020-10-31 18:42:56 +0000 UTC 2020-10-31 18:42:56 +0000 UTC

如何填写地图?

  • 772

任务如下:我需要编写一个将一些文本作为输入并返回的方法Map,该方法存储该文本中每个文字字符的重复次数。我把字符串拆分成一个字符数组,存入ArrayList,排序,然后计算每个字符重复了多少次,现在我需要把它Map放入 这是我到目前为止所做的:

public static Map<Character, Integer> countSymbolsNew(String text)throws Exception{
        //сделать отсортированный список
        //посчитать количество повторений каждого символа и занести в переменную
        //результат добавить в мапу
        if (text == null)
            throw new Exception("No text");

    Map<Character, Integer> map = new HashMap<>();
    ArrayList<Character> chars = new ArrayList<>();
    for (int i = 0; i < text.length(); i++) {
        char c = text.toLowerCase().charAt(i);
        if (Character.isLetter(c)){
            chars.add(c);
        }
    }
    Collections.sort(chars);
    System.out.println(chars);
    //надо взять первый элемент массива, пройти им по всему списку и если повторяется то плюсовать счетчик
    //если не повторился то счетчик равен 1
    int maxCount = 0;
    for (Character aChar : chars) {
        int count = 0;
        for (Character ch : chars) {
            if (aChar.equals(ch)){
                count++;
            }
        }
        if (count > maxCount){
            maxCount = count;
        }
        System.out.print(count + " ,");

    }


    return map;
}

理论上,我有点想象元素是如何添加到地图中的,但实际上,我无法做任何进一步的事情。请帮忙解释一下。

java
  • 3 3 个回答
  • 10 Views

3 个回答

  • Voted
  1. Best Answer
    KoVadim
    2020-10-31T19:15:53Z2020-10-31T19:15:53Z

    如果“导师”建议对数组进行排序并且显然害怕做额外的放置(嗯,一个人的头脑中没有太多 bzyk),那么你可以这样做。原则上,简单地添加map.put(aChar, count)已经解决了问题,甚至@Roman Danilov 也写了这个。但是这个解决方案有一个缺点——二次复杂度。如果数组没有排序,那么人们可能对此视而不见。但是数组已经排序了,所以相同的元素在一行中。你只需要跑起来总结一下。某处如此

    public static Map<Character, Integer> countSymbolsNew(String text)throws Exception{
            //сделать отсортированный список
            //посчитать количество повторений каждого символа и занести в переменную
            //результат добавить в мапу
            if (text == null)
                throw new Exception("No text");
    
        Map<Character, Integer> map = new HashMap<>();
        ArrayList<Character> chars = new ArrayList<>();
        for (int i = 0; i < text.length(); i++) {
            char c = text.toLowerCase().charAt(i);
            if (Character.isLetter(c)){
                chars.add(c);
            }
        }
        Collections.sort(chars);
        System.out.println(chars);
    
        Character c = chars.get(0);
        int count = 1;
        for (int i = 1; i < chars.size(); i++) {
            // проверим текущий символ. я не знаю, можно ли тут просто равно
            if (chars.get(i).equals(c)) {
                // символ тот же - просто счетчик увеличим
                count++;
            } else {
               // другой символ, добавим предыдущий и запомним новый
                map.put(c, count);
                c = chars.get(i);
                count = 1;
            }
        }
        // а это уже хвост, который также нужно обработать.
        map.put(c, count);
    
        return map;
    }
    
    • 1
  2. Roman Danilov
    2020-10-31T18:54:48Z2020-10-31T18:54:48Z

    如果它很简单并且没有 Java8 特性,那么这就足够了:

    public static Map<Character, Integer> countSymbolsNew(String text)throws Exception {
        if (text == null)
            throw new Exception("No text");
    
        Map<Character, Integer> map = new HashMap<>();
        for (int i = 0; i < text.length(); i++) {
            char c = text.toLowerCase().charAt(i);
            if (Character.isLetter(c)) {
                if (map.containsKey(c)) {
                    map.put(c, map.get(c) + 1);
                } else {
                    map.put(c, 1);
                }
            }
        }
        return map;
    }
    

    在这里,我们只是遍历字符数组并将每个字符放入映射中。如果这样的符号已经存在,我们只需将相同的符号放在地图中,但计数器会增加,而旧的会被覆盖。

    如果按照您的方式做很重要,那么您可以执行以下操作:

    //надо взять первый элемент массива, пройти им по всему списку и если повторяется то плюсовать счетчик
    //если не повторился то счетчик равен 1
    for (Character aChar : chars) {
        if (!map.containsKey(aChar)) {
            int count = 0;
            for (Character ch : chars) {
                if (aChar.equals(ch)){
                    count++;
                }
            }
            System.out.print(count + " ,");
            map.put(aChar, count);
        }
    }
    
    • 0
  3. Дмитрий
    2020-10-31T20:26:22Z2020-10-31T20:26:22Z
    public Map <Character, Integer> letterCalculate (String text){
        Map <Character, Integer> mapCounter = new TreeMap <>();
        for (char ch : text.toCharArray()) {
            if (Character.isLetter(ch)) mapCounter.put(ch, mapCounter.get(ch) == null ? 1 : mapCounter.get(ch) + 1);
        }
        return mapCounter;
    }
    
    • 0

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    Python 3.6 - 安装 MySQL (Windows)

    • 1 个回答
  • Marko Smith

    C++ 编写程序“计算单个岛屿”。填充一个二维数组 12x12 0 和 1

    • 2 个回答
  • Marko Smith

    返回指针的函数

    • 1 个回答
  • Marko Smith

    我使用 django 管理面板添加图像,但它没有显示

    • 1 个回答
  • Marko Smith

    这些条目是什么意思,它们的完整等效项是什么样的

    • 2 个回答
  • Marko Smith

    浏览器仍然缓存文件数据

    • 1 个回答
  • Marko Smith

    在 Excel VBA 中激活工作表的问题

    • 3 个回答
  • Marko Smith

    为什么内置类型中包含复数而小数不包含?

    • 2 个回答
  • Marko Smith

    获得唯一途径

    • 3 个回答
  • Marko Smith

    告诉我一个像幻灯片一样创建滚动的库

    • 1 个回答
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Алексей Шиманский 如何以及通过什么方式来查找 Javascript 代码中的错误? 2020-08-03 00:21:37 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    user207618 Codegolf——组合选择算法的实现 2020-10-23 18:46:29 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5