Форум программистов, компьютерный форум, киберфорум
Delphi для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
 Аватар для Diamond_Seraph
0 / 0 / 0
Регистрация: 31.08.2011
Сообщений: 15

Переставить члены последовательности так, чтобы сначала расположились все ее неотрицательные члены

16.10.2011, 12:58. Показов 1716. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите решить задачу!
:cofee2:
Дана очередь, элементами которой являются действительные числа. Переставить ее члены так, чтобы сначала расположились все ее неотрицательные члены, а потом - все отрицательные. Порядок как среди неотрицательных членов, так и среди отрицательных должен быть сохранен прежним. Для временного хранения неотрицательных и отрицательных элементов использовать стеки. Значения элементов очереди до и после перестановки вывести на экран.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.10.2011, 12:58
Ответы с готовыми решениями:

Переставить члены последовательности так, чтобы сначала расположились все ее неотрицательные члены
Помогите пожалуйста решить задачу!!! Экзамен горит.... Выручайте!!! Дана очередь, элементами которой являются действительные числа....

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

Переставить очередь, чтобы сначала расположились все ее неотрицательные члены, а потом — все отрицательные
Помогите написать код, пожалуйста! :wall: Составить очередь, элементами которой являются действительные числа. Переставить ее члены...

1
Эксперт функциональных языков программированияЭксперт по математике/физике
4310 / 2102 / 431
Регистрация: 19.07.2009
Сообщений: 3,184
Записей в блоге: 24
16.10.2011, 17:54
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Идея: имеем исходный очередь q с числами и два дополнительных pos и neg для положительных и отрицательных чисел. Описываю в общепринятых обозначениях в предположении, что структуры стека и очереди описаны.
1. Пока q не пуст:
2. Вытаскиваем первый элемент очереди element:=q.next;
3. Проверяем на неотрицательность (переходим к п.4 и п.5 соответственно) if element>0 then
4. (Если положительный) Добавляем положительное число в соотв. стек pos.push(element)
5. (Если отрицательный) Добавляем отрицательное число в соотв. стек neg.push(element)
6. Когда q станет пустым, начинаем добавлять в него элементы в правильном порядке.
Тут один момент есть: в стеках сверху находятся элементы, которые в очереди были ближе к концу.
Они будут извлекаться из стека в первую очередь (т.е. в приоритете). В очередь же мы добавляем по-порядку. А это значит, что вот просто так не получиться взять и "перегнать" сначала из одного стека в очередь, а потом из второго в один заход, поскольку порядок отрицательных (и положительных) элементов будет инвертирован. Стало быть, необходимо сделать одну из трех вещей:
1. Если очередь организована массивом, объявить очередь стеком и затолкать в нужном порядке элементы.
2. Инвертировать оба стека, затем добавить элементы в очередь.
3. Добавить элементы в очередь, затем инвертировать очередь.

Под "добавить элементы со стеков в очередь" я подразумеваю (с точностью до порядка 2 и 3 строки)
Delphi
1
2
3
q.clear;
while not pos.isEmpty do q.add(pos.pop);
while not neg.isEmpty do q.add(neg.pop);
Идею описал подробно, попробуй самостоятельно её реализовать; если не получится, опиши, что не получается (объявить структуры данных / описать взаимодействия и т.п.)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.10.2011, 17:54
Помогаю со студенческими работами здесь

Упорядочить массив так, чтобы сначала иши упорядоченные положительные члены а потом упорядоченные отрицательные члены
упорядочить одномерный массив таким образом,чтобы сначала ии упорядоченные положительные члены а потом упорядоченные по возрастанию...

Упорядочить массив так, чтобы сначала иши упорядоченные положительные члены а потом упорядоченные отрицательные члены
1 упорядочить одномерный массив таким образом,чтобы сначала ии упорядоченные положительные члены а потом упорядоченные по возрастанию...

Упорядочить массив так, чтобы сначала иши упорядоченные положительные члены а потом упорядоченные отрицательные члены
упорядочить одномерный массив таким образом,чтобы сначала шли упорядоченные положительные члены а потом упорядоченные по возрастанию...

Переставить элементы массива так, чтобы в начале массива расположились все его неотрицательные элементы
Дан массив а1,а2,…,аn. Переставить его элементы так, чтобы в начале массива расположились все его неотрицательные элементы, а в конце –...

Дан массив а1,а2,,…,аn. Переставить его элементы так, чтобы в начале массива расположились все его неотрицательные элементы, а в конце – отрицательные
Помогите плиз написать программу: Дан массив а1,а2,,…,аn. Переставить его элементы так, чтобы в начале массива расположились все его...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru