Форум программистов, компьютерный форум CyberForum.ru

Очереди (С) - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.80
Savaj
0 / 0 / 0
Регистрация: 17.03.2011
Сообщений: 6
17.03.2011, 21:27     Очереди (С) #1
Доброго времени суток. Необходима помощь в задаче

Разработать функцию, которая упорядочит элементы очереди по возрастанию (в процессе упорядочивания элементы очереди перемещаться не должны).

буду благодарен за помощь
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
lavan
51 / 51 / 1
Регистрация: 21.03.2009
Сообщений: 371
17.03.2011, 22:33     Очереди (С) #2
не совсем понятно условие,очередь это АТД.на нее накладываются определенные требования, первый пришел,первый ушел,т.е в очередь можно присоеденить новый елемент в конец и взять на обработку из начала.может нужно отсортировать связный список?
Sick2
14 / 14 / 1
Регистрация: 26.11.2010
Сообщений: 235
18.03.2011, 00:32     Очереди (С) #3
Извиняюсь, конечно, но нельзя ли использовать обычную сортировку? Т.е. мы вводим сначала данные в массив, сортируем, и потом записываем все эти элементы в очередь. М?
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
18.03.2011, 00:41     Очереди (С) #4
Savaj, Если действительно нужно отсортировать очередь - стоит смело слать на вики, чтобы человек, давший задание увидел, что такое очередь и пусть человек приведет объяснение на кой сортировать структуру данных, которая в прямом смысле для этого не предназначена никаким боком.
silent_1991
18.03.2011, 09:53
  #5

Не по теме:

ForEveR, я бы в другое место послал, но на вики тоже можно, для начала...

Savaj
0 / 0 / 0
Регистрация: 17.03.2011
Сообщений: 6
18.03.2011, 11:26  [ТС]     Очереди (С) #6
вот и я не понимаю смысла такой сортировки..Но сдать лабу нужно..
Но как поставить их по возрастанию.. если нельзя менять местами.
Был вариант менять местами указатели ...
bigredcat
364 / 311 / 3
Регистрация: 24.02.2011
Сообщений: 1,512
Записей в блоге: 1
18.03.2011, 11:46     Очереди (С) #7
Ну так получите длину очереди. Создайте динамический массив для хранения сортированных элементов. Извлекайте из очереди элемент. Скопируйте его значение. Вставьте в конец очереди.
Savaj
0 / 0 / 0
Регистрация: 17.03.2011
Сообщений: 6
18.03.2011, 11:55  [ТС]     Очереди (С) #8
Массив использовать нельзя...
буду дальше ломать голову..
bigredcat
364 / 311 / 3
Регистрация: 24.02.2011
Сообщений: 1,512
Записей в блоге: 1
18.03.2011, 12:01     Очереди (С) #9
Цитата Сообщение от Savaj Посмотреть сообщение
Массив использовать нельзя...
буду дальше ломать голову..
А где отсортированные элементы тогда хранить?
Сомневаюсь, что вы задание правильно изложили?
Savaj
0 / 0 / 0
Регистрация: 17.03.2011
Сообщений: 6
18.03.2011, 12:09  [ТС]     Очереди (С) #10
задание скопированно с книги ) ошибки точно не может быть. Человек который дал это задание утвержает , что все легко делается.
bigredcat
364 / 311 / 3
Регистрация: 24.02.2011
Сообщений: 1,512
Записей в блоге: 1
18.03.2011, 12:17     Очереди (С) #11
Ну у вас получается оригинал (очередь) не менять (и это правильно).
Но и элементы из очереди никуда не копироватьО_о. В каком-то пятом измерении их сортировать что ли
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
18.03.2011, 16:05     Очереди (С) #12
Тут, похоже, присутствует следующая совокупность факторов:
1. Очередь хранится в виде списка, и из условия "элементы во время сортировки перемещаться не должны" следует, что надо менять не элемент в узлах списка, а указатели на соседей у каждого из узлов, представляющих обмениваемые элементы.
2. Человек, который давал задания, не понимаете смысла очереди и представляет себе сортировку не элементов очереди, а сортировку элементов списка.
Пока эта пара факторов объясняет, что надо сделать и почему употребили термин "Очередь".
Savaj
0 / 0 / 0
Регистрация: 17.03.2011
Сообщений: 6
18.03.2011, 18:39  [ТС]     Очереди (С) #13
Цитата Сообщение от silent_1991 Посмотреть сообщение
Тут, похоже, присутствует следующая совокупность факторов:
1. Очередь хранится в виде списка, и из условия "элементы во время сортировки перемещаться не должны" следует, что надо менять не элемент в узлах списка, а указатели на соседей у каждого из узлов, представляющих обмениваемые элементы.
2. Человек, который давал задания, не понимаете смысла очереди и представляет себе сортировку не элементов очереди, а сортировку элементов списка.
Пока эта пара факторов объясняет, что надо сделать и почему употребили термин "Очередь".
Человек который мне дал это задание - это мой препод по программухе )
да , мне кажется нужно менять местами указатели. Но как это делать - я не представляю.

Если кто сможет помочь , буду очень благодарен
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
18.03.2011, 18:51     Очереди (С) #14
Цитата Сообщение от Savaj Посмотреть сообщение
Человек который мне дал это задание - это мой препод по программухе
Это не панацея от некомпетентности.
Savaj
0 / 0 / 0
Регистрация: 17.03.2011
Сообщений: 6
19.03.2011, 11:52  [ТС]     Очереди (С) #15
тема все еще актуальна... все еще нужна помощь
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
19.03.2011, 12:44     Очереди (С)
Еще ссылки по теме:

Объединить две очереди в одну, как создать две очереди C++
Очереди C++
Очереди (С++) C++

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

Или воспользуйтесь поиском по форуму:
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
19.03.2011, 12:44     Очереди (С) #16
Господи, да по сортировке списков туча тем на этом форуме и ещё туча в квадрате по всему рунету. Неужели так сложно самому вбить в поисковик запрос и не ждать, пока это за вас сделает другой?
Yandex
Объявления
19.03.2011, 12:44     Очереди (С)
Ответ Создать тему
Опции темы

Текущее время: 10:14. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru