Отображение массива символов 2 на 2 символа - PullRequest
0 голосов
/ 01 мая 2020

У меня есть массив символов, например, XXYYXYXYXZXZXZXYXX, и я хочу сопоставить его с LinkedHashMap двумя двумя символами, как показано ниже:

public LinkedHashMap<String, Integer> convert(char[] array) {

    LinkedHashMap<String, Integer> map = new LinkedHashMap<String, Integer>();

    int[] freq = new int[array.length];
    int i, j;

    for (i = 0; i < array.length; i+=2) {
        freq[i] = 1;
        for (j = i + 2; j < array.length; j+=2) {
            if (array[i] + array[i+1] == array[j] + array[j+1]) {
                freq[i]++;
                array[j] = '0'; //flag to check if it is already printed
                array[j+1] = '0'; //flag to check if it is already printed
            }
        }
    }

    for (i = 0; i < freq.length; i+=2) {
        if (array[i] + array[i+1] != ' ' && array[i] != '0') {                
            String dublex = ""+ array[i] + array[i+1];
            hmap.put(dublex, freq[i]);
        }
    }
    return hmap;
}

Обычно в нем должны быть следующие значения: XX: 2 YY: 1 XY : 3 XZ: 3

Но ему присваиваются следующие значения: XX: 2 YY: 4 XY: 3 XZ:? недоступно

Я сомневаюсь в следующих строках и точках:

1) Я попытался использовать другое значение l oop, например "k", для переменной count freq [] и попытался подсчитать это между 0-9, так как 18 элементов - это 9 двухсимвольных элементов: я пытался сделать это, но не имеет смысла и выбрасывает исключение.

2) "0" части добавлены в конец значений: Я пытался добавить отдельные 0 значений и проверить отдельно, например array[i] != '0' && array[i+1] != '0'

Итак, как решить проблему?

Ответы [ 2 ]

2 голосов
/ 01 мая 2020
    public static LinkedHashMap<String, Integer> convert(char[] array) {
        LinkedHashMap<String, Integer> map = new LinkedHashMap<String, Integer>();

        for (int i = 0; i < array.length - 1; i += 2) {
            map.put(array[i] + "" + array[i + 1], map.getOrDefault(array[i] + "" + array[i + 1], 0) + 1);
        }

        return map;
    }

    public static void main(String[] args) {
        System.out.println(convert("XXYYXYXYXZXZXZXYXX".toCharArray()));
    }

, выход

{XX=2, YY=1, XY=3, XZ=3}
1 голос
/ 01 мая 2020

Это просто перефразировка ответа sc0der , опубликованного по запросу в шестнадцатеричном формате.

static Map<String, Integer> pairFreq(char[] array)
{
    LinkedHashMap<String, Integer> map = new LinkedHashMap<>();
    for(int i=0; i<array.length; i+=2)
    {
        String key = new String(array, i, 2);
        map.put(key, 1 + map.getOrDefault(key, 0));
    }
    return map;
}

Тест:

String str = "XXYYXYXYXZXZXZXYXX";
Map<String, Integer> map = pairFreq(str.toCharArray());
for(String pair : map.keySet())
    System.out.println(pair + " : " + map.get(pair));

Вывод:

XX : 2
YY : 1
XY : 3
XZ : 3
...