|
0 / 0 / 1
Регистрация: 04.03.2011
Сообщений: 90
|
||||||||||||
Алгоритм сортировки слов по алфавиту05.02.2012, 14:38. Показов 3633. Ответов 9
Метки нет (Все метки)
Здравствуйте! Очень надо,помогите пожалуйста, написала программы на паскале в асэмблере но на делфи дали трудную тему "Алгоритм сортировки слов по алфавиту" с использованием параллельного програмирования и 16 нитями. Очень нужна помощь, помогите пожалуйста. Вот что то пыталась из интернета искала:
0
|
||||||||||||
| 05.02.2012, 14:38 | |
|
Ответы с готовыми решениями:
9
Хранимая процедура сортировки числового поля для сортировки по алфавиту Дан список слов различной длины. Составить программу упорядочения списка слов: По их длине; По алфавиту вывод сортировки по алфавиту (ошибка) |
|
0 / 0 / 1
Регистрация: 04.03.2011
Сообщений: 90
|
|
| 06.02.2012, 08:05 [ТС] | |
|
может кто помоч написать? я на окно мемо1 мемо2 и бутон скинула, не могу написать с параллельным программированием на 16 нитей(
0
|
|
|
13116 / 5897 / 1708
Регистрация: 19.09.2009
Сообщений: 8,809
|
||
| 06.02.2012, 09:03 | ||
|
--- Класс TStringList уже имеет готовый метод для сортировки по алфавиту - об этом выше уже упомянул Alex_pac - это метод TStringList.Sort(). Если надо именно TStringList применять, то достаточно создать 16 потоков на экземплярах класса TThread и в их методах TThread.Execute() вызывать метод TStringList.Sort(). Но можно и самостоятельно сортировку реализовать.
0
|
||
|
0 / 0 / 1
Регистрация: 04.03.2011
Сообщений: 90
|
||||||
| 06.02.2012, 10:13 [ТС] | ||||||
|
ну вот я сделала более простую сортировку без параллельного
"проблема в том, что сортировку вот так вот просто не распаррелелить. как я сказал, можно делить интервал на равные части и порождать нить. чтобы 16 потоков (или нитей) породить, количество слов должно быть достаточно большим - штук 100 и т.п. иначе, это будет надуманно. 16 потоков будут порождены не одновременно, а поэтапно. на первом шаге - 2, на втором эти два породят каждый по два - 4, и т.д. 4-8, 8 - 16. 16 - 32 и так далее, пока не кончатся слова" и меню я хотела сделать сверху слева там о программе и всё такое стереть с мемо1 что то типо токого хотя это в принцепи не важно, вот на счёт TThread он много говарил видимо надо через этот путь делать. Добавлено через 26 минут блин запуталась... (
0
|
||||||
|
13116 / 5897 / 1708
Регистрация: 19.09.2009
Сообщений: 8,809
|
|
| 06.02.2012, 11:06 | |
|
Если надо сортировать 16 разных списков слов в 16-ти потоках. - Это сделать достаточно просто.
![]() Но вот если надо сортировать один и тот же список слов с помощью 16-ти потоков - эта задача существенно сложнее. В этом случае я вижу, например, такой способ. - Выбираем сортировку вставками. Идёт перебор элементов от начала к концу списка. При этом область, в которой происходит поиск позиции вставки, располагается от начала списка до текущей позиции сортировки. Эта область вставки по мере сортировки постоянно увеличивается и в конце сортировки становится равной размеру списка (размер списка минус один). Вот, как раз, для поиска позиции вставки в этой области и можно применить несколько параллельных потоков. Например, в начале сортировки используем 1 поток поиска позиции вставки. Когда текущая позиция сортировки достигает отметки в 2000 слов, то можно запустить уже второй поток. При этом, действия между потоками будут распределены так - первый поток ищет позицию вставки в области с индексами 1000..1999, второй поток ищет в области индексов: 1..999. Когда позиция сортировки достигнет 3000 слов, то можно запустить третий поток. Потом, когда текущая позиция сортировки окажется равной 4000 слов - запускаем 4-й поток. И т. д. Т. е. мы делим всю область поиска вставки на количество потоков, распределяем диапазон индексов для потоков - какой поток в пределах каких индексов ищет позицию вставки. --- fait218, уточни этот момент - как всё-таки надо делать - сортировать 16 разных списков 16-ю потоками или сортировать один список 16-ю потоками. Первый вариант решается достаточно просто. А второй - существенно сложнее.
0
|
|
|
0 / 0 / 1
Регистрация: 04.03.2011
Сообщений: 90
|
|
| 07.02.2012, 11:53 [ТС] | |
|
блин( всё печально я уточнила и надо делать вторым способом , я порылась , всётаки думала первый там как ты обьеснил по проще, но он сказал что делать надо вторым вариантом(
Добавлено через 3 часа 21 минуту ёмаё всё напутала можно сделать и первым способом но я что то не могу там распараллелить ( Добавлено через 1 час 7 минут Блин ребята помогите пожалуста а то у меня уже голова болит( честно запуталась теперь капец полный( Добавлено через 18 часов 57 минут ребят ну помогите пожалусто(
0
|
|
|
39 / 71 / 10
Регистрация: 03.02.2012
Сообщений: 362
|
|
| 07.02.2012, 13:02 | |
|
Как тебе помочь если ты сама не знаешь, что тебе надо.
Сортировка в 16 потоков это бред.
0
|
|
|
13116 / 5897 / 1708
Регистрация: 19.09.2009
Сообщений: 8,809
|
|
| 07.02.2012, 14:34 | |
|
Да, больно уж большое количество потоков. 16 - это всё-таки перебор. Ну 2 или 3 потока для учебного задания. Но 16... - это всё-таки тяжёлый случай.
0
|
|
|
39 / 71 / 10
Регистрация: 03.02.2012
Сообщений: 362
|
|
| 07.02.2012, 15:27 | |
|
Переименуйте форум в "Я не ходил на пары. Сделайте мне курсовую".
Может 16 нитей это метод сортировки? Вообще-то, оптимальным будет решение с 2-я потоками. Одни сортирует по первой букве, а второй по всей длинне слова (например перелом, переплавка).
0
|
|
| 07.02.2012, 15:27 | |
|
Помогаю со студенческими работами здесь
10
Вывести элементы, присутствующие в обоих массивах А и В. Алгоритм сортировки - подсчетом, алгоритм поиска - двоичный
Дописать функцию сортировки по алфавиту в базе данных Организация сортировки выводимого списка по алфавиту и рейтингу Сделать файл f содержащий М слов. Выполнить сортировку слов методом быстрой сортировки. Переписать весь текст в обратном Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|
Настройки VS Code
Loafer 13.04.2026
{
"cmake. configureOnOpen": false,
"diffEditor. ignoreTrimWhitespace": true,
"editor. guides. bracketPairs": "active",
"extensions. ignoreRecommendations": true,
. . .
|
|
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2.
Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива.
Было так:. . .
|
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: реализовать контроль корректности заполнения дат назначения. . .
|
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html
Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
|
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача №1: при указании работ (справочник РаботыПоРемонтуСпецтехники),. . .
|