Мега Таракан
 Аватар для .: TAPAKAH :.
110 / 11 / 5
Регистрация: 24.05.2010
Сообщений: 227

В одномерном массиве (в массиве n элементов) удалить все элементы стоящие между минимальным положительным и максимальным отрицательным элементом

08.12.2011, 22:05. Показов 3263. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый вечер!) Помогите с задачкой: В одномерном массиве (в массиве n элементов) удалить все элементы стоящие между минимальным положительным и максимальным отрицательным элементом

Вот мое неверное решение
Pascal
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
Var
  Arr : Array Of Integer;
  i, j, N, Max, Min, i_max, i_min : Integer;
Begin
  Randomize;
  Write('Введите размер массива: ');
  ReadLn(N);
  SetLength(Arr, N);
  Max := -50;
  Min := 50;
//Заполняем массив случайными числами в -50..50. Также находим минимальный и максимальный элемент
  For i := 0 To N - 1 Do
    Begin
      Arr[i] := Random(101) - 50;
        Write(Arr[i]:3);
      If Arr[i] > Max Then
        Max := Arr[i];
      If Arr[i] < Min Then
        Min := Arr[i];
    End;
WriteLn;
//Нахождение минимального положительного и максимального отрицательного элемента
    For i := 0 To N - 1 Do
      Begin
        If (Arr[i] < Max) And (Arr[i] > 0) Then
              Begin
            Max := Arr[i];
                i_max := i;
              End;
      If (Arr[i] > Min) And (Arr[i] < 0) Then
        Begin
              Min := Arr[i];
              i_min := i;
            End;
      End;
      
    If i_min > i_max Then
      Begin
        i_min := i_min + i_max; 
        i_max := i_min - i_max; 
        i_min := i_min - i_max;
      End;
      
    For i := i_min + 1 To i_max - 1 Do
      Begin
        For j := i To i_max Do
          Arr[j] := Arr[j + 1];
      Dec(i_max);
      End;
    
    For i := 0 To N - 1 Do
      Write(Arr[i]:3);  
End.

Где может быть ошибка??

Заранее спасибо)

Добавлено через 1 час 4 минуты
Я минимальные положительные и максимальные отрицательные элементы нашел, а вот как их удалить - хз
В моем коде по идее вот это
Pascal
1
2
3
4
5
6
For i := i_min + 1 To i_max - 1 Do
      Begin
        For j := i To i_max Do
          Arr[j] := Arr[j + 1];
          Dec(i_max);
      End;
должно удалять эти элементы

 Комментарий модератора 
Заголовок темы изменен модератором.
Он должен быть информативным, отображая содержание темы.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.12.2011, 22:05
Ответы с готовыми решениями:

В массиве удалить все элементы стоящие между минимальными положительным и максимальным отрицательным
составить программу заданной обработки массива целых чисел,используя перестановку элементов внутри массива не создавая новых.исходный и...

Удалить все элементы массива, стоящие между минимальным положительным и максимальным отрицательным элементами
Помогите плиззз=((( Задание:В массиве A=(a1, а2, ..., аn) удалить все элементы, стоящие между минимальным положительным и максимальным...

В двухмерном массиве удалить все элементы, стоящие между минимальным положительным и максимальным отрицательным
В двухмерном массиве 10x10 удалить все элементы, стоящие между минимальным положительным и максимальным отрицательным элементами.

3
Почетный модератор
 Аватар для КонецСвета
7966 / 3937 / 2464
Регистрация: 30.10.2011
Сообщений: 5,377
08.12.2011, 22:34
Pascal
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
uses crt;
var a: array [1..100] of integer;
    i,max,imax,min,imin,dz,nz,n: integer;
begin
write('n=');
readln(n);
max:=-51; min:=51;
for i:=1 to n do
    begin
    a[i]:=random(101)-50;
    write(a[i]:4);
    if (a[i]>0) and (a[i]<min) then
       begin
       min:=a[i];
       imin:=i;
       end;
    if (a[i]<0) and (a[i]>max) then
       begin
       max:=a[i];
       imax:=i;
       end;
    end;
if imin<imax then
   begin
   nz:=imin+1;
   dz:=imax-imin-1;
   end else
   begin
   nz:=imax+1;
   dz:=imin-imax-1;
   end;
writeln;
writeln('Мин. из пол. ',min,' под номером ',imin);
writeln('Макс. из отр. ',max,' под номером ',imax);
for i:=nz to n do
    a[i]:=a[i+dz];
n:=n-dz;
for i:=1 to n do
    write(a[i]:4);
end.
1
Саша2323
26.12.2011, 21:34
Можете показать это на С???
0 / 0 / 0
Регистрация: 03.04.2012
Сообщений: 8
04.04.2012, 11:14
https://www.cyberforum.ru/pascal/thread538192.html а вот с этим заданием, пожалуйста, помогите разобраться...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.04.2012, 11:14
Помогаю со студенческими работами здесь

Удалить все элементы, стоящие между минимальным положительным и максимальным отрицательным элементами
В массиве A=(a1, а2, ..., аn) удалить все элементы, стоящие между минимальным положительным и максимальным отрицательным элементами.

Удалить все элементы списка, стоящие между минимальным положительным и максимальным отрицательным элементами
Ребят, помогите плиз. Python Элементы списка нужно вводить с помощью random. В списке А=(а1,а2,...,аn) удалить все элементы, стоящие...

В массиве все положительные элементы, стоящие перед минимальным положительным элементом, переслать в хвост массива
В массиве A=( a1, а2, ..., аn) все положительные элементы, стоящие перед минимальным положительным элементом, переслать в «хвост» массива. ...

В массиве все положительные элементы, стоящие перед минимальным положительным элементом, переслать в хвост массива
В массиве A=(a1, а2, ..., аn) все положительные элементы, стоящие перед минимальным положительным элементом, переслать в «хвост» массива....

В заданном массиве М (14) заменить все отрицательные элементы, стоящие на четных местах, его максимальным элементом, а на нечетных - его минимальным э
В заданном массиве М (14) заменить все отрицательные элементы, стоящие на четных местах, его максимальным элементом, а на нечетных - его...


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

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

Новые блоги и статьи
Компиляция C++ с Clang API
NullReferenced 24.03.2025
Компиляторы обычно воспринимаются как черные ящики, которые превращают исходный код в исполняемые файлы. Мы запускаем компилятор командой в терминале, и вуаля — получаем бинарник. Но что если нужно. . .
Многопоточное программировани­е в C#: Класс Thread
UnmanagedCoder 24.03.2025
Когда запускается приложение на компьютере, операционная система создаёт для него процесс - виртуальное адресное пространство. В C# этот процесс изначально получает один поток выполнения — главный. . .
SwiftUI Data Flow: Передача данных между представлениями
mobDevWorks 23.03.2025
При первом знакомстве со SwiftUI кажется, что фреймворк предлагает избыточное количество механизмов для передачи данных: @State, @Binding, @StateObject, @ObservedObject, @EnvironmentObject и другие. . . .
Моки в Java: Сравниваем Mockito, EasyMock, JMockit
Javaican 23.03.2025
Как протестировать класс, который зависит от других сложных компонентов, таких как базы данных, веб-сервисы или другие классы, с которыми и так непросто работать в тестовом окружении? Для этого и. . .
Архитектурные паттерны микросервисов: ТОП-10 шаблонов
ArchitectMsa 22.03.2025
Популярность микросервисной архитектуры объясняется множеством важных преимуществ. К примеру, она позволяет командам разработчиков работать независимо друг от друга, используя различные технологии и. . .
Оптимизация рендеринга в Unity: Сортировка миллиона спрайтов
GameUnited 22.03.2025
Помните, когда наличие сотни спрайтов в игре приводило к существенному падению производительности? Время таких ограничений уходит в прошлое. Сегодня геймдев сталкивается с задачами совершенно иного. . .
Образование и практика
Igor3D 21.03.2025
Добрый день А вот каково качество/ эффективность ВУЗовского образования? Аналитическая геометрия изучается в первом семестре и считается довольно легким курсом, что вполне справедливо. Ну хорошо,. . .
Lazarus. Таблица с объединением ячеек.
Massaraksh7 21.03.2025
Понадобилась представление на экране таблицы с объединёнными ячейками. И не одной, а штук триста, и все разные. На Delphi я использовал для этих целей TStringGrid, и то, кривовато получалось. А в. . .
Async/await в Swift: Асинхронное программировани­е в iOS
mobDevWorks 20.03.2025
Асинхронное программирование долго было одной из самых сложных задач для разработчиков iOS. В течение многих лет мы сражались с замыканиями, диспетчеризацией очередей и обратными вызовами, чтобы. . .
Колмогоровская сложность: Приёмы упрощения кода
ArchitectMsa 20.03.2025
Наверное, каждый программист хотя бы раз сталкивался с кодом, который напоминает запутанный лабиринт — чем дальше в него погружаешься, тем сложнее найти выход. И когда мы говорим о сложности кода, мы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru