Форум программистов, компьютерный форум, киберфорум
PascalABC.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 10.11.2016
Сообщений: 22

Удалить первый отрицательный элемент из очереди

02.09.2018, 20:21. Показов 1080. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Описать процедуру, которая удаляет из очереди первый отрицательный элемент, если такой есть.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
02.09.2018, 20:21
Ответы с готовыми решениями:

Удалить из массива первый отрицательный элемент
Дан массив, содержащий положительные и отрицательные числа. Удалить из него первый отрицательный элемент

Добавить элемент со значением D в конец очереди и извлечь из очереди первый (начальный) элемент
Дано число D и указатели P1 и P2 на начало и конец очереди, содержащей не менее двух элементов. Добавить элемент со значением D в конец...

Найти первый отрицательный элемент массива и первый положительный элемент и поменять их местами
Найти первый отрицательный элемент массива и первый положительный элемент и поменять их местами.

2
Эксперт Pascal/Delphi
2388 / 1300 / 1492
Регистрация: 29.08.2014
Сообщений: 4,665
03.09.2018, 06:36
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
54
55
56
57
58
59
60
61
62
63
64
type
  Ochered=^O;
  O=record
      d:integer;
      next:Ochered;
   end;
procedure AddElem(var l,r:Ochered;c:integer);
var
  t:Ochered;
begin
  new(t);
  t^.d:=c;
  t^.next:=nil;
  if l=nil then l:=t  else r^.next:=t;
  r:=t;
end;
 
procedure DelFirstOtrElem(var l,r:Ochered);
var
  t,z:Ochered;
begin
  z:=nil;
  if l=nil then exit;//очередь пустая
  t:=l;
  if t^.d<0 then begin //первый элемент <0
    l:=l^.next;
    dispose(t);
    exit;
  end;  
  while t^.next<>nil do begin
    if (t^.next^.d<0) and (z=nil) then z:=t;
    t:=t^.next;
  end;  
  if z<>nil then begin
      if z^.Next=r then r:=z;
      t:=z^.next;
      z^.next:=z^.next^.next;
      dispose(t);
    end;
end;  
  
procedure printochered(l,r:Ochered);
var
  t:Ochered;
begin
  t:=l;
  while t^.next<>nil do begin
    write(t^.d:4);
    t:=t^.next;
  end;  
  writeln;
end;  
var
  l,r:Ochered;
  i:integer;
begin
  randomize;
  for i:=1 to 10 do AddElem(l,r,random(100)-50);
//  write('Очередь:');
  printochered(l,r);
  DelFirstOtrElem(l,r);  //твоя процедура
//  writeln('Полученная очередь:');
  printochered(l,r);
end.
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33400 / 21510 / 8236
Регистрация: 22.10.2011
Сообщений: 36,910
Записей в блоге: 12
03.09.2018, 10:54
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// Вот она, нужная процедура:
procedure DelFirstNegative(var q : Queue<integer>);
begin
  var found := false;
  for var i := 1 to q.Count do
  begin
    var first := q.Dequeue;
    if not found and (first < 0) then found := true else q.Enqueue(first);
  end;  
end;
 
begin
  var q : Queue<integer> := new Queue<integer>(Arr(1, -2, 3, 4, -5, -6, 7, 8));
 
  q.Println;
  DelFirstNegative(q);
  q.Println;
end.
, про написание своей реализации очереди в задании ничего не было сказано.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
03.09.2018, 10:54
Помогаю со студенческими работами здесь

Удалить первый отрицательный элемент массива, если такой элемент есть
1. Удалить первый отрицательный элемент массива, если такой элемент есть. 2. Вставить два элемента с данными значениями: первый – после...

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

Удалить первый отрицательный элемент
Заполнить массив из 10 элементов случайными числами в интервале . Вывести массив на экран. Удалить первый отрицательный элемент. Вывести на...

Удалить из массива А (20) первый отрицательный элемент
Удалить из массива А (20) первый отрицательный элемент. #include &lt;stdio.h&gt; #include &lt;stdlib.h&gt; int main() { int...

Удалить из массива первый отрицательный элемент
Удалить из массива размером 20 элементов первый отрицательный элемент. Язык СИ.


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды "Заполнить" и "Очистить" на форме документа
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". На примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных выбран регистр накопления, в. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru