0 / 0 / 0
Регистрация: 08.07.2022
Сообщений: 7

Вернуть копию массива со всеми удаленными локальными максимумами

26.07.2022, 11:25. Показов 3696. Ответов 7

Студворк — интернет-сервис помощи студентам
Привет! Прошу помощи с заданием.
Задача:
Перейдите в класс LocalMaximaRemove и реализуйте метод removeLocalMaxima.
Правильная реализация должна получить массив значений типа int и вернуть копию данного массива со всеми удаленными локальными максимумами. Исходный массив изменять нельзя.
Локальный максимум — это элемент, который больше любого из его соседних элементов. Вам необходимо удалить элементы, которые являются локальными максимумами в исходном массиве.
Подробности:
Размер данного массива гарантированно больше 1.
Данный массив гарантированно не равен null.
Если у массива нет локальных максимумов, то вы должны вернуть его копию без изменений.
Вы можете использовать методы java.util.Arrays.*.
Пример
Ввод:
[18, 1, 3, 6, 7, -5]
Вывод в консоли:
[1, 3, 6, -5]

Мой код:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
public class LocalMaximaRemove {
 
    public static void main(String[] args) {
        int[] array = new int[]{18, 1, 3, 6, 7, -5};
        System.out.println(Arrays.toString(array));
        System.out.println(Arrays.toString(removeLocalMaxima(array)));
    }
 
    public static int[] removeLocalMaxima(int[] array){
        int localMaxNumber = 0; //количество локальных максимумов
        for (int i=0; i < array.length-1; i++) {
            if (i == 0) {
                if (array[i] > array[i+1]) {
                    localMaxNumber++;
                    System.out.println(array[i]);
                }
            } else if (i == array.length-1) {
                if (array[i] > array[i-1]) {
                    localMaxNumber++;
                    System.out.println(array[i]);
                }
            } else {
                if (array[i] > array[i-1] && array[i] > array[i+1]) {
                    localMaxNumber++;
                    System.out.println(array[i]);
                }
            }
        }
        int[] array2 = new int[array.length - localMaxNumber];
        if (localMaxNumber != 0) {
            for (int i = 0; i < array.length-1; i++) {
                if (i == 0) {
                    if (array[i] < array[i+1]) {
                        System.arraycopy(array, i, array2, i, 1);
                    }
                } else if (i == array.length-1) {
                    if (array[i] < array[i-1]) {
                        System.arraycopy(array, i, array2, i-1, 1 );
                    }
                } else {
                    if (array[i] < array[i-1] || array[i] < array[i+1]) {
                        if (array2[i-1] == 0) {
                            System.arraycopy(array, i, array2, i-1, 1);
                        } else {
                            System.arraycopy(array, i, array2, i, 1);
                        }
                    }
                }
            }
        } else {
            return array;
        }
        return array2;
    }
}


То есть: находим локальные максимумы -> если они есть -> создаем новый массив длиной меньше исходного на количество локальных максимумов -> копируем элементы в новый массив, кроме локальных максимумов.
... -> если локальных максимумов нет -> возвращаем исходный массив без изменений

Мой результат:
[18, 1, 3, 6, 7, -5] // исходный массив
18 // локальный максимум
7 // локальный максимум
[1, 3, 6, 0] // полученный массив


Правильный ли ход решения вообще? И я засел на условии else if (i == array.length-1), с ним засада. Помогите, подскажите
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.07.2022, 11:25
Ответы с готовыми решениями:

Наименьшее расстояние между локальными максимумами
Определите наименьшее расстояние между двумя локальными максимумами последовательности натуральных чисел, завершающейся числом 0. Локальным...

Расстояние между двумя локальными максимумами
Написал программу для поиска минимального расстояния между локальными максимумами, но она почему-то неверная, а где именно я так и не...

Наименьшее расстояние между локальными максимумами
Определите наименьшее расстояние между двумя локальными максимумами последовательности натуральных чисел, завершающейся числом 0. Если в...

7
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
26.07.2022, 12:23
если a[i] - локальный максимум, увеличить счетчик количества максимумов
иначе, запистаь в новый массив

создать еще один массив, скопировать туда элементы второго массива
1
Заблокирован
26.07.2022, 13:10
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
import java.util.Arrays;
 
public class Main 
{
    public static void main(String[] args) 
    {
        int[] array = new int[]{18, 1, 3, 6, 7, -5, 9};
        System.out.println(Arrays.toString(array));
        System.out.println(Arrays.toString(removeLocalMaxima(array)));
    }
    
    public static int[] removeLocalMaxima(int[] a)
    {
        for (int i=0; i<a.length; i++)
            if(i==0 || a[i-1]<a[i] && i==a.length-1 || a[i+1]<a[i])
            {
                int[] b = new int[a.length-1];
                System.arraycopy(a,0,b,0,i);
                if(i<a.length-1)
                    System.arraycopy(a,i+1,b,i,a.length-i-1);
                a=b.clone();
            }
        return a;
    }
}
1
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
26.07.2022, 13:40
Цитата Сообщение от Biger18 Посмотреть сообщение
int[] b = new int[a.length-1];
не смысла создавать новый массив для каждого максимума
Цитата Сообщение от Biger18 Посмотреть сообщение
System.arraycopy(a,0,b,0,i);
                if(i<a.length-1)
                    System.arraycopy(a,i+1,b,i,a.length-i-1);
также как нет смысла делать arrayCopy 100500 раз
Цитата Сообщение от Biger18 Посмотреть сообщение
a=b.clone();
ну и еще один clone()
слишком много бессмысленных операций

Добавлено через 56 секунд
Цитата Сообщение от Biger18 Посмотреть сообщение
a[i+1]<a[i]
а вот тут вообще исключение будет
1
0 / 0 / 0
Регистрация: 08.07.2022
Сообщений: 7
26.07.2022, 17:25  [ТС]
В итоге работающий код у меня выглядит так:

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
public class LocalMaximaRemove {
 
    public static void main(String[] args) {
        int[] array = new int[] {18, 1, 3, 6, 7, -5};
        System.out.println(Arrays.toString(array));
        System.out.println(Arrays.toString(removeLocalMaxima(array)));
    }
 
    public static int[] removeLocalMaxima(int[] array){
        int localMaxNumber = 0; //количество локальных максимумов
        for (int i=0; i < array.length; i++) {
            if (i == 0) {
                if (array[i] > array[i+1]) {
                    localMaxNumber++;
                    System.out.println(array[i]);
                }
            } else if (i == array.length-1) {
                if (array[i] > array[i-1]) {
                    localMaxNumber++;
                    System.out.println(array[i]);
                }
            } else {
                if (array[i] > array[i-1] && array[i] > array[i+1]) {
                    localMaxNumber++;
                    System.out.println(array[i]);
                }
            }
        }
        int[] array2 = new int[array.length - localMaxNumber];
        if (localMaxNumber != 0) {
            int notLocalMaxNumberArrayIndex = 0; //индекс нелокального максимума в массиве array2
            for (int i = 0; i < array.length; i++) {
                if (i == 0) {
                    if (array[i] < array[i + 1]) {
                        System.arraycopy(array, i, array2, i, 1);
                        notLocalMaxNumberArrayIndex++;
                    }
                } else if (i == array.length-1) {
                    if (array[i] < array[i - 1]) {
                        System.arraycopy(array, i, array2, array2.length - 1, 1 );
                    }
                } else {
                    if (array[i] <= array[i-1] || array[i] <= array[i+1]) {
                        System.arraycopy(array, i, array2, notLocalMaxNumberArrayIndex, 1);
                        notLocalMaxNumberArrayIndex++;
                    }
                }
            }
        } else {
            return array;
        }
        return array2;
    }
}

Наверняка решение не самое элегантное) Буду рад критике, если есть что доработать.
0
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
26.07.2022, 17:43
DenSebrovsky, Вернуть копию массива со всеми удаленными локальными максимумами
перечитай
0
0 / 0 / 0
Регистрация: 08.07.2022
Сообщений: 7
27.07.2022, 08:55  [ТС]
Я немного по-другому сделал - не создавал еще 1 промежуточный массив, а сразу копировал нужные элементы в финальный массив
0
0 / 0 / 0
Регистрация: 19.04.2023
Сообщений: 1
19.04.2023, 17:47
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
    public static int[] removeLocalMaxima(int[] array) {
        List<Integer> arrayIndex = new ArrayList<>();
        for (int i = 0; i < array.length; i++) {
            if (i == 0) {
                if(array[i] > array[i + 1]) {
                    arrayIndex.add(i);
                }
                continue;
            }
            if (i == (array.length - 1) && array[i] > array[i - 1]) {
                arrayIndex.add(i);
                continue;
            }
            if (array[i] > array[i - 1] && array[i] > array[i + 1]) {
                arrayIndex.add(i);
                continue;
            }
        }
        int []result =new int[array.length - arrayIndex.size()];
        for (int i=0,j=0;i<array.length;i++){
            if(!arrayIndex.contains(i)){
                result[j]=array[i];
                j++;
            }
        }
        return result;
    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.04.2023, 17:47
Помогаю со студенческими работами здесь

Наименьшее расстояние между двумя локальными максимумами
Определите наименьшее расстояние между двумя локальными максимумами последовательности натуральных чисел, завершающейся числом 0. Если в...

Найти наименьшее расстояние между локальными максимумами
Определите наименьшее расстояние между двумя локальными максимумами последовательности натуральных чисел, завершающейся числом 0. Локальным...

Неверно считается расстояние между локальными максимумами
Всем привет, проблемка - вроде, написал всё логично, понять, где ошибка в моём коде, не могу. Задание: Определите наименьшее...

Нахождение минимального колическта пробелов между локальными максимумами
Здравствуйте, уважаемые господа пограммисты! Дана вот такая задача : Определите наименьшее расстояние между двумя локальными...

определить наименьшее расстояние между двумя локальными максимумами
Ребят, помогите пожалуйста, разобраться с кодом. Объясните, в чем ошибаюсь? Идентичный вопрос уже задавался на форуме, но мне интересно,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

Новые блоги и статьи
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru