Создание массива из другого массива? - PullRequest
0 голосов
/ 08 марта 2020

Впервые до java, и я работаю с кодировкой RLE, и я пытаюсь создать программу, которая принимает байтовый массив, а затем возвращается с другим байтовым массивом, но он принимает количество последовательных значений в массиве и затем печатает [( количество повторений), (значение)]. Например, [13,13,13,3,3,3,3] вернет [3,13,4,3]

import java.util.Arrays;

public class testing {

    public static void main(String [] args) {

        byte [] pracArray = {13,13,13,3,3,3,3};

        int count = 1;

        for (int i = 0; i <pracArray.length-1; i++)
        {
            if (pracArray[i] != pracArray[i+1])
            {
                count++;
            }
        }

        byte numLength = 1;
        byte indexNum = 0;
        int newArraySize = count*2;

        byte [] newArray = new byte [newArraySize];

        for ( int i = 0; i < pracArray.length-1; i++)
        {
            if (pracArray[i] != pracArray[i+1] )
            {
                newArray[indexNum] = numLength;
                newArray[indexNum+1] = pracArray[i];
                indexNum = (byte) (indexNum + 2);
                numLength = 1;
            }
            else
            {
                numLength++;
            }
        }
        System.out.println(Arrays.toString((pracArray)));
        System.out.println(Arrays.toString((newArray)));
    }
}

Мне известно о моей проблеме - последний запуск последовательных чисел не печатается. Если я изменю массив на [13,13,13,3,3,3,3,1], он напечатает [3,13,4,3,0,0], последняя последовательность чисел никогда не записывается, поэтому последние два значения newArray никогда не заполняются. Любые идеи о том, как я могу изменить свое заявление if, чтобы включить мою последнюю последовательность чисел?

1 Ответ

1 голос
/ 08 марта 2020

По окончании l oop проверьте, равен ли последний элемент второму последнему элементу.

Ваш обновленный код будет:

import java.util.Arrays;

public class Main {
    public static void main(String[] args) {

        byte[] pracArray = { 13, 13, 13, 3, 3, 3, 3, 1 };

        int count = 1;

        for (int i = 0; i < pracArray.length - 1; i++) {
            if (pracArray[i] != pracArray[i + 1]) {
                count++;
            }
        }

        byte numLength = 1;
        byte indexNum = 0;
        int newArraySize = count * 2;

        byte[] newArray = new byte[newArraySize];
        int i;
        for (i = 0; i < pracArray.length - 1; i++) {
            if (pracArray[i] != pracArray[i + 1]) {
                newArray[indexNum] = numLength;
                newArray[indexNum + 1] = pracArray[i];
                indexNum = (byte) (indexNum + 2);
                numLength = 1;
            } else {
                numLength++;
            }
        }
        if (pracArray[i - 1] == pracArray[i]) {
            newArray[indexNum] = numLength;
            newArray[indexNum + 1] = pracArray[i];
            indexNum = (byte) (indexNum + 2);
            numLength = 1;
        } else {
            newArray[indexNum] = numLength;
            newArray[indexNum + 1] = pracArray[i];
        }

        System.out.println(Arrays.toString((pracArray)));
        System.out.println(Arrays.toString((newArray)));
    }
}

Вывод:

[13, 13, 13, 3, 3, 3, 3, 1]
[3, 13, 4, 3, 1, 1]

Вывод для byte[] pracArray = { 13, 13, 13, 3, 3, 3, 3 } будет следующим:

[13, 13, 13, 3, 3, 3, 3]
[3, 13, 4, 3]
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...