Удаление дубликатов из массива без коллекций, простой вопрос - PullRequest
0 голосов
/ 12 марта 2019

Итак, во-первых, пожалуйста, прости меня за этот вопрос, это может быть глупо, но что с этой строкой кода:

if (array[i] == newArray[j]) 

Допустим, у нас есть массив с элементами {1,1,2,2,3,4,5} и когда вы создаете новый массив: int[] newArray = new int[array.length], вы в основном инициализируете его нулями, теперь появляется строка, которую я вам сказал, как вы можете проверить факт, что 1 == 0 или следующий 1 == 0, каждый раз, когда вы проверяете равенство, вы будете проверить с нуля, или я что-то упустил? Пожалуйста, кто-нибудь объяснит.

public static int[] removeDuplicates(int[] array) {
        Arrays.sort(array);

        int[] newArray = new int[array.length];
        for (int i : newArray) {
            System.out.print(i + " ");
        }
        int counter = 0;

        for (int i = 0; i < array.length; i++) {
            boolean isDuplicate = false;
            for (int j = 0; j < newArray.length; j++) {
                if (array[i] == newArray[j]) {
                    isDuplicate = true;
                }
            }

            if (!isDuplicate) {
                newArray[counter] = array[i];
                counter++;
            }
        }
        int[] result = Arrays.copyOf(newArray,counter);
        return result;
    }

1 Ответ

1 голос
/ 12 марта 2019

Измените цикл j, чтобы использовать counter в качестве верхней границы, а не newArray.length, поэтому вы сравниваете только значения, уже скопированные в newArray. Таким образом, вы никогда не сравнитесь с неназначенным 0-значным слотом.

Для повышения производительности вы должны добавить оператор break после установки isDuplicate = true, так как нет необходимости продолжать сканирование newArray.

...