0 / 0 / 0
Регистрация: 12.11.2018
Сообщений: 25
|
|
1 | |
Удалить все элементы, стоящие между минимальным положительным и максимальным отрицательным элементами12.11.2018, 10:52. Показов 5602. Ответов 10
Метки visual studio 2010 (Все метки)
В массиве A=(a1, а2, ..., аn) удалить все элементы, стоящие между минимальным положительным и максимальным отрицательным элементами.
0
|
|
12.11.2018, 10:52 | |
Ответы с готовыми решениями:
10
В двухмерном массиве удалить все элементы, стоящие между минимальным положительным и максимальным отрицательным
Все положительные элементы, стоящие перед минимальным положительным элементом, переслать в «хвост» массива Отсортируйте элементы массива, расположенные между первым положительным и последним отрицательным элементами массива. |
12.11.2018, 11:39 | 2 | |||||
![]() Решение
Кирилл4316, получите:
1
|
0 / 0 / 0
Регистрация: 12.11.2018
Сообщений: 25
|
||||||
12.11.2018, 13:59 [ТС] | 3 | |||||
Я понял что этот кусок кода удаляет элементы, можно по подробнее что и как работает
0
|
12.11.2018, 18:03 | 4 |
Кирилл4316, объясняю:
1. Так как массив - штука постоянная, то удалить оттуда элементы можно только переопределением самого массива, поэтому сначала мы заводим себе список list тип List<int>(), в который можно добавлять подходящие элементы. 2. Дальше, мы нашли нижний (first) и верхний (last) индексы, между которыми значения нам не нужны. 3. В цикле мы обходим все элементы массива и, если индекс i больше нижнего индекса и меньше верхнего индекса, то мы берём следующую итерацию цикла (со строки 4 переходим к строке 2). Если индекс i в то условие не попадает, то выполняется строка 5.
0
|
0 / 0 / 0
Регистрация: 12.11.2018
Сообщений: 25
|
|
12.11.2018, 18:13 [ТС] | 5 |
Спасибо разобрался. Еще вопрос, еще нужно сделать все тоже самое только с двухмерным массивом, как это реализовать
0
|
12.11.2018, 18:38 | 6 |
Кирилл4316
Для двумерного массива я не могу представить как будет работать этот алгоритм. Вот когда Вы мне объясните как удалить элемент матрицы, не разрушив её структуры, тогда можно что-нибудь придумать... А что скажут мэтры программирования? ![]()
0
|
0 / 0 / 0
Регистрация: 12.11.2018
Сообщений: 25
|
|
12.11.2018, 18:42 [ТС] | 7 |
Ну на форуме подсказали развернуть матрицу в одномерный массив удалить элементы и свернуть обратно в двухмерный
0
|
0 / 0 / 0
Регистрация: 12.11.2018
Сообщений: 25
|
|
12.11.2018, 18:55 [ТС] | 9 |
А просто пустыми оставить можно? Если нельзя то, тогда заполнить нулями скорее всего
0
|
12.11.2018, 19:25 | 10 |
Если это целочисленный двумерный массив, то заполнение только нулями (хотя можно представить элементы типом <int?>)
А если это массив действительных чисел, то можно пустые ячейки обозначать как double.NaN
0
|
0 / 0 / 0
Регистрация: 12.11.2018
Сообщений: 25
|
||||||
12.11.2018, 19:37 [ТС] | 11 | |||||
Вот что получается пока что, не подскажете как теперь как заполнить нулями и свернуть обратно?
0
|
12.11.2018, 19:37 | |
Помогаю со студенческими работами здесь
11
Отсортируйте элементы массива, расположенные между первым положительным и последним отрицательным элементами массива.
Элементы находящиеся между максимальным и минимальным элементами массива занести в другой массив Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |