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

По одной очереди построить две новых из положительных и отрицательных элементов

09.06.2014, 19:52. Показов 1278. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Описать процедуру, которая по одной очереди строит две новых:Queue1 из положительных элементов и Queue2 - из остальных элементов очереди
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.06.2014, 19:52
Ответы с готовыми решениями:

Описать процедуру, которая по одной очереди строит две новых - из положительных и остальных
Описать процедуру, которая по одной очереди строит две новых: Queue1 из положительных элементов и Queue2 - из остальных элементов очереди...

Из положительных и отрицательных элементов исходного массива сформировать два новых
3.Составьте программу формирования из массива A двух массивов, в которых первый массив заполнен отрицательными, а второй - положительными...

Из положительных и отрицательных элементов исходного массива сформировать два новых
3*. Составьте программу формирования из массива A(N) двух массивов, в которых первый массив заполнен положительными, а второй –...

10
0 / 0 / 1
Регистрация: 12.08.2014
Сообщений: 59
12.08.2014, 19:46
Такой процедуры не существует
0
Модератор
10429 / 5717 / 3404
Регистрация: 17.08.2012
Сообщений: 17,384
12.08.2014, 23:38
Цитата Сообщение от Ринат1999 Посмотреть сообщение
Такой процедуры не существует
Ну и что? А написать её кто мешает?
0
 Аватар для APALoff
1648 / 1077 / 1081
Регистрация: 03.07.2013
Сообщений: 4,507
13.08.2014, 10:10
Например так:
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 = ^dan;
  dan = Record
          data : Integer;
          next : Ochered;
        end;
Var
  q0,q1,q2 : Ochered;
 
Procedure DisposeItem(Var qq : Ochered);
Var tmp : Ochered;
Begin
  While qq<>nil do
  Begin
    tmp:=qq;
    qq:=qq^.next;
    Dispose(tmp);
  end;
end;
 
Procedure AddNewItem(Var qq : Ochered; NewData : Integer);
Var tmp,tt : Ochered;
Begin
  New(tmp);
  tmp^.data:=NewData;
  tmp^.next:=nil;
  tt:=qq;
  If tt=nil then qq:=tmp
  else
    Begin
      While tt^.next<>nil do tt:=tt^.next;
      tt^.next:=tmp;
    end;
end;
 
Procedure SplitOchered(qqq : Ochered; Var qq1,qq2: Ochered);
Begin
  While qqq<>nil do
  Begin
    If qqq^.data>0 then AddNewItem(qq1,qqq^.data) else AddNewItem(qq2,qqq^.data);
    qqq:=qqq^.next;
  end;
end;
 
Procedure ShowOchered(z : Ochered);
Begin
  While z<>nil do
  Begin
    Write(z^.data,'  ');
    z:=z^.next;
  end;
end;
 
Begin
  q0:=nil; q1:=nil; q2:=nil;
  For var i:integer:=-5 to 5 do AddNewItem(q0,i);
  ShowOchered(q0); Writeln(#13,#10);
  SplitOchered(q0,q1,q2);
  ShowOchered(q1); Writeln(#13,#10);
  ShowOchered(q2); Writeln(#13,#10);
  DisposeItem(q0);
  DisposeItem(q1);
  DisposeItem(q2);  
end.
0
154 / 154 / 81
Регистрация: 16.06.2012
Сообщений: 314
14.08.2014, 19:47
И вот вариант, когда очередь похожа на себя, а не в виде списка
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
uses crt;
 
type pitem = ^item;
     item = record
         data : integer;
         next : pitem;
     end;
     queue = record
         first , last : pitem;
     end;
 
var common , positive , negative : queue;
    i : integer;
 
procedure init_queue(var q : queue);
begin
    q.first := nil;
    q.last := nil;
end;
 
procedure add_item(var q : queue ; data : integer);
var t : pitem;
begin
    new(t);
    t^.data := data;
    t^.next := nil;
    if q.first = nil then begin
        q.first := t;
        q.last := t;
    end else begin
        q.last^.next := t;
        q.last := t;
    end;
end;
 
procedure split(var q : queue; var positive , negative : queue);
var t , tt : pitem;
    data : integer;
begin
    t := q.first;
    while t <> nil do begin
        data := t^.data;
        if data >= 0 then
            add_item(positive , data)
        else
            add_item(negative , data);
        tt := t;
        t := t^.next;
        dispose(tt);    
    end;
end;
 
procedure print_queue(q : queue);
var t : pitem;
begin
    t := q.first;
    while t <> nil do begin
        write(t^.data , ' ');
        t := t^.next;
    end;
    writeln;
end;
 
procedure clean_queue(var q : queue);
var t , tt : pitem;
begin
    t := q.first;
    while t <> nil do begin
        tt := t;
        t := t^.next;
        dispose(tt);
    end;
end;
 
begin
    init_queue(common); init_queue(positive); init_queue(negative);
    randomize;
    for i := 1 to 10 do
        add_item(common , -10 + random(21));
    writeln('Initial queue: ');
    print_queue(common);    
    split(common , positive , negative);
    writeln('Positive: ');
    print_queue(positive);
    writeln('Negative: ');
    print_queue(negative);
    clean_queue(positive);
    clean_queue(negative);
    readkey;
end.
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33393 / 21503 / 8236
Регистрация: 22.10.2011
Сообщений: 36,899
Записей в блоге: 12
14.08.2014, 20:26
Без написания своего, используем готовый класс Queue<T>
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
uses System.Collections.Generic;
 
procedure Print(myQueue : Queue<integer>);
begin
  foreach v : integer in myQueue do write(v:4);
  writeln;
end;
 
begin
  var q : Queue<integer> := new Queue<integer>;
  for var i := -10 to 20 do
    q.Enqueue(i);
  Print(q);
  
  var queue1 : Queue<integer> := new Queue<integer>;
  var queue2 : Queue<integer> := new Queue<integer>;
  var queues : array[boolean] of Queue<integer> := (queue1, queue2);
  
  while q.Count > 0 do
  begin
    var v := q.Dequeue;
    queues[v > 0].Enqueue(v);
  end;
  Print(queue1);
  Print(queue2);
end.
0
 Аватар для APALoff
1648 / 1077 / 1081
Регистрация: 03.07.2013
Сообщений: 4,507
14.08.2014, 21:14
Цитата Сообщение от igor_kz Посмотреть сообщение
когда очередь похожа на себя, а не в виде списка
На что это Вы намекаете? Что у меня не очередь? Я всегда считал, что очередь, это когда "последний пришел - последний и ушел" и тут не важно, двусвязный список или односвязный - разница только в реализации алгоритма.
0
154 / 154 / 81
Регистрация: 16.06.2012
Сообщений: 314
14.08.2014, 21:20
Цитата Сообщение от APALoff Посмотреть сообщение
Что у меня не очередь
Понятие верное, проблема в добавлении. Чтобы добавить один элемент в очередь, Вы проходите всю очередь. Смысл? Из линейного алгоритма Вы сделаете квадратичный. И в принципе, тут как раз и теряется уже смысл как структуры данных. А ведь можно лишь хранить указатель на последний элемент. Попрактикуйтесь )
З. Ы. А так мне нравится уже готовый класс)
0
 Аватар для APALoff
1648 / 1077 / 1081
Регистрация: 03.07.2013
Сообщений: 4,507
14.08.2014, 21:37
igor_kz, я намеренно пошел на односвязный - т.к. здесь большего и не требуется, и да, я мог при моем варианте использовать дополнительные указатели на конечные элементы - но это увеличение переменных, а чем их меньше тем лучше (ИМХО), да и код получается проще/короче и меньше возможностей напутать с двухсторонними указателями.
0
154 / 154 / 81
Регистрация: 16.06.2012
Сообщений: 314
14.08.2014, 21:57
Ну теперь я начинаю сомневаться в Ваших знаниях. Советую изучить материал по вопросам односвязных и двухсвязных списков.
О том, что просят в условии: здесь просят очередь, а не список, который Вы представили.
Меньше переменных не есть хорошо, вообще фантастика) Лучше добавить одну переменную, немного проиграв в памяти, но зато прилично улучшив асимптотику.
0
 Аватар для APALoff
1648 / 1077 / 1081
Регистрация: 03.07.2013
Сообщений: 4,507
14.08.2014, 22:10
Ну не знаю, "на вкус и цвет - товарища нет"... во всяком случае мой вариант вышел покороче.
Останемся каждый при своём мнении.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
14.08.2014, 22:10
Помогаю со студенческими работами здесь

Сформировать из массива два новых: первый — из отрицательных элементов, второй — из положительных
Задать массив случайными вещественными числами в диапазоне значений от -90 до +100. Сформировать из него два массива: первый - из...

Массив из 10 целых чисел Создать два новых массива из положительных и отрицательных элементов
Ввести в stringGrid массив из 10 целых чисел Создать два новых массива из положительных и отрицательных элементов исходного массива ...

По списку L построить два новых списка: L1 – из положительных элементов и L2 – из остальных
Имеются линейные однонаправленные списки: type p=^item; item=record data:real; reference: end;Написать программу, которая по...

Массив: Сформировать из элементов двух массивов два новых: один - из положительных, а второй - из отрицательных...
Даны два одномерных массива целых чисел (массив A, состоящий из n элементов, массив B - из m элементов), заполненных случайным образом...

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


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Семь 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. На борту пять. . .
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru