|
79 / 67 / 28
Регистрация: 22.04.2016
Сообщений: 384
|
|||||||||||
Реализовать многопоточную сортировку динамического массива целых чисел01.11.2016, 21:52. Показов 3203. Ответов 48
Метки нет (Все метки)
Есть задание:
Написать программу, которая выполняет сортировку динамического массива целых чисел, количество элементов которого задает пользователь после соответствующего запроса. Реализовать однопоточную и многопоточную сортировку массива. Отсортированный массив записать в файл. Все, что нужно реализовать для однопоточности - я сделал. Для однопоточной сортировки я реализовал быструю сортировку. А вот с многопоточной сортировкой беда (в данном случаи, я выбрал сортировку Шелла с применением последовательности Седжвика). Никак не получается. Подскажите, пожалуйста, правильный алгоритм многопоточной сортировки массива или же наведите пример. Ссылки на материалы, туториалы также приветствуются. Свой код прилагаю: Файл ArraySorting.h
0
|
|||||||||||
| 01.11.2016, 21:52 | |
|
Ответы с готовыми решениями:
48
Реализовать сортировку двумерного динамического массива
Как организовать сортировку динамического массива |
|
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
|
|
| 03.11.2016, 22:50 | |
|
0
|
|
|
79 / 67 / 28
Регистрация: 22.04.2016
Сообщений: 384
|
||||||
| 03.11.2016, 23:05 [ТС] | ||||||
|
nd2, вот здесь:
0
|
||||||
|
710 / 283 / 16
Регистрация: 31.03.2013
Сообщений: 1,340
|
|||
| 03.11.2016, 23:22 | |||
Типа: "В C++ нет потоков, в C++ потоки имитирует std::thread", или скажем "В C++ нет работы с файлами, в C++ подобное имитирует std::iofstream", "В C++ нет сортировки, её имитирует std::sort".Так что-ли?
1
|
|||
|
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
|
|
| 03.11.2016, 23:44 | |
|
0
|
|
|
Неэпический
|
|||
| 03.11.2016, 23:48 | |||
|
но данный функционал предоставляет стандартная библиотека. так что, начиная с C++11 можно сказать, что многопоточность в C++ есть, а вот расширяющихся массивов как не было, так и нет.
0
|
|||
|
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
|
|
| 03.11.2016, 23:51 | |
|
0
|
|
|
710 / 283 / 16
Регистрация: 31.03.2013
Сообщений: 1,340
|
||
| 04.11.2016, 00:22 | ||
|
А то иначе возможны интересные утверждения уровня "В С++ нет списков инициализации, их имитирует std::initializer_list" или "В C++ нет RTTI, его имитирует содержимое хедера typeinfo"
0
|
||
|
Неэпический
|
||
| 04.11.2016, 00:29 | ||
|
А иначе получается, что в главе Arrays должны описываться массивы и std::array. Всё-таки вектор не массив, вектор - контейнер, реализующий функционал динамического массива (как структуры данных), к тому же вектор опять не массив - он шаблон класса.
1
|
||
|
710 / 283 / 16
Регистрация: 31.03.2013
Сообщений: 1,340
|
|||
| 04.11.2016, 00:39 | |||
![]()
0
|
|||
|
Неэпический
|
|||||||||
| 04.11.2016, 00:50 | |||||||||
|
В языке есть конкретный тип данных - массив. В языке нет типа данных - двусвязный список. Имеются классы. Есть шаблоны классов. В стандартной библиотеке есть конкретный шаблон класса, который реализует список. Но std::list != тип данный список. типов больше быть не может. Если где-нибудь в шаблоне забыть о том, что массив != класс != указатель, то можно отхватить по башке. Класс != массив, какую бы структуру данных он там не реализовывал.
GbaLog- писал о массиве как о типе языка, вы же сюда каким-то боком структуры данных приплели. Предлагаю закончить.
0
|
|||||||||
|
710 / 283 / 16
Регистрация: 31.03.2013
Сообщений: 1,340
|
|||
| 04.11.2016, 01:07 | |||
|
0
|
|||
|
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
|
|||||||||||||
| 04.11.2016, 05:01 | |||||||||||||
myArray.arrayCopys(); нужно инициализировать два массива, которые будешь в потоках сортировать:
shellSorting() непонятно что творится. После такой сортировки - в массивах мусор.Добавлено через 5 минут И не забудь, что размер исходного массива должен делиться на два без остатка.
1
|
|||||||||||||
|
Любитель чаепитий
|
|||||
| 04.11.2016, 12:54 | |||||
Я немного покопался и думаю, что это всего-лишь обёртка над std::FILE. Не стоит разводить холивар и на эту тему, я скажу, в С++ есть работа с файлами и она предоставляется STL. Это алгоритм. Об моём видении динамических массивов в С++ Вам уже Croessmah всё сказал. А вообще, если навскидку подумать, то динамическим массивом называть можно то, что отхапывает себе доп. память сразу за последним элементом, а не то, что выделяет новый блок и туда все старые элементы переносит. Ну или, в самом страшном случае, если места нет, то отхапывает в другом месте и в последний элемент старого впечатывает указатель на новый, гораздо эффективнее, чем всё переносить.
0
|
|||||
|
79 / 67 / 28
Регистрация: 22.04.2016
Сообщений: 384
|
||||||||||||
| 04.11.2016, 21:57 [ТС] | ||||||||||||
|
nd2, все (надеюсь, что все) замечания исправил/подправил.
Файл ArraySorting.h
0
|
||||||||||||
|
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
|
|||
| 04.11.2016, 22:56 | |||
|
Добавлено через 4 минуты
0
|
|||
|
79 / 67 / 28
Регистрация: 22.04.2016
Сообщений: 384
|
|
| 04.11.2016, 23:01 [ТС] | |
|
nd2, исправил. Но проблема осталась.
0
|
|
|
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
|
|
| 04.11.2016, 23:02 | |
|
1
|
|
|
79 / 67 / 28
Регистрация: 22.04.2016
Сообщений: 384
|
|
| 04.11.2016, 23:02 [ТС] | |
|
0
|
|
|
3438 / 2817 / 1249
Регистрация: 29.01.2016
Сообщений: 9,427
|
|
| 04.11.2016, 23:02 | |
|
0
|
|
|
79 / 67 / 28
Регистрация: 22.04.2016
Сообщений: 384
|
|
| 04.11.2016, 23:02 [ТС] | |
|
Понял. Сейчас.
0
|
|
| 04.11.2016, 23:02 | |
|
Помогаю со студенческими работами здесь
40
Реализовать линейный однонаправленный список на базе массива целых чисел
Реализовать сортировку массива структур по заданному полю
Реализовать и протестировать функцию создания двумерного динамического массива Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
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 .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|