Мега Таракан
110 / 11 / 5
Регистрация: 24.05.2010
Сообщений: 227
1

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

08.12.2011, 22:05. Показов 3254. Ответов 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 удалить все элементы, стоящие между минимальным положительным и...

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

3
Почетный модератор
7966 / 3937 / 2464
Регистрация: 30.10.2011
Сообщений: 5,377
08.12.2011, 22:34 2
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 3
Можете показать это на С???
0 / 0 / 0
Регистрация: 03.04.2012
Сообщений: 8
04.04.2012, 11:14 4
https://www.cyberforum.ru/pascal/thread538192.html а вот с этим заданием, пожалуйста, помогите разобраться...
0
04.04.2012, 11:14
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.04.2012, 11:14
Помогаю со студенческими работами здесь

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

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

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

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

Найти количество положительных элементов между между максимальным элементом и минимальным элементом в массиве A(20)
Найти количество положительных элементов между между максимальным элементом и минимальным элементом...

Найти в массиве сумму элементов расположенных между максимальным четным и последним отрицательным элементом
Здравствуйте знатаки! Нужно найти в массиве сумму элементов расположенных между максимальным...


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

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

Новые блоги и статьи
NoSQL базы данных: что это такое и какие существуют
bytestream 22.01.2025
В современную эпоху цифровой трансформации объемы данных растут экспоненциально, создавая новые вызовы для традиционных систем управления базами данных. NoSQL (Not Only SQL) представляет собой. . .
Обновление исследования от команды MCM (январь 2025 г.)
Programma_Boinc 22.01.2025
Обновление исследования от команды MCM (январь 2025 г. ) Мы продолжаем изучать молекулярные сигнатуры, связанные с раком легких, с текущим фокусом на GCM1, факторе транскрипции, участвующем в. . .
Как работать с Kafka в Go (Golang)
bytestream 22.01.2025
Apache Kafka представляет собой распределенную платформу потоковой передачи данных, которая произвела революцию в области обработки событий и интеграции микросервисов. Эта система, изначально. . .
Как использовать RabbitMQ в Go (Golang)
bytestream 22.01.2025
RabbitMQ представляет собой надежный и широко используемый брокер сообщений, который играет ключевую роль в построении современных распределенных систем и микросервисной архитектуры. В основе работы. . .
Как преобразовать список списков в простой список в Python
bytestream 22.01.2025
При работе с Python разработчики часто сталкиваются с необходимостью обработки сложных структур данных, среди которых особое место занимают вложенные списки. Эти структуры представляют собой списки,. . .
Что такое GUID / UUID и как их создать
bytestream 22.01.2025
В мире разработки программного обеспечения существует постоянная потребность в уникальной идентификации объектов, записей и ресурсов. Эта задача становится особенно актуальной в распределенных. . .
Как добавить пустую директорию в репозиторий Git
bytestream 22.01.2025
При работе с системой контроля версий Git разработчики часто сталкиваются с ситуацией, когда необходимо сохранить пустую директорию в репозитории. Данная задача может показаться простой на первый. . .
Как валидировать адрес email в JavaScript
bytestream 22.01.2025
JavaScript, как основной язык веб-разработки, предоставляет разработчикам множество инструментов для реализации эффективной валидации email-адресов. От простых встроенных решений до сложных. . .
Как заменить все вхождения подстроки в JavaScript
bytestream 22.01.2025
Строки в JavaScript представляют собой неизменяемые последовательности символов, что делает их обработку особенно интересной с точки зрения оптимизации и выбора правильного подхода к решению задач. . . .
Управление версиями пакетов в Node.js. В чем разница между тильдой (~) и кареткой (^) в package.json
bytestream 22.01.2025
В современной разработке программного обеспечения управление версиями пакетов играет ключевую роль в обеспечении стабильности и надежности проектов. Node. js, как одна из самых популярных платформ для. . .
Аутентификация на сайте с помощью формы
bytestream 21.01.2025
В современном цифровом мире безопасная аутентификация становится краеугольным камнем защиты веб-приложений и пользовательских данных. Каждый день миллионы людей используют различные онлайн-сервисы,. . .
Как получить индекс в цикле for в Python
bytestream 21.01.2025
При работе с коллекциями данных в Python часто возникает необходимость не только получить доступ к элементам последовательности, но и знать их позицию в процессе итерации. Индексация в циклах. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru