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

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

26.07.2022, 11:25. Показов 3672. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3, Box2D, FreeType и SDL3_ttf из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru