Форум программистов, компьютерный форум, киберфорум
Java для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/18: Рейтинг темы: голосов - 18, средняя оценка - 4.83
0 / 0 / 0
Регистрация: 08.07.2022
Сообщений: 7

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

26.07.2022, 11:25. Показов 3618. Ответов 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
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru