1. Заголовок или название темы должно быть информативным !
2. Все тексты фрагментов программ должны помещаться в теги [code] ... [/code] или [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ" и используйте ПОИСК !
4. НЕ используйте форум для личного общения!
5. Самое главное - это раздел теоретический, т.е. никаких задач и программ (за исключением небольших фрагментов) - для этого есть отдельный раздел!
| Gendalf |
16.12.2007 15:20
Сообщение
#1
|
|
Гость |
Подскажите пожалуйста наилучший алгорит сортировки записей в типизированном файле. фаил безразмерный, и желательно не использовать буферные файлы.
В FAQ прочитал про методы сортировок, но они все сортировки массивов, а нет ли какой-нибудь сортировки, предназначенной для сортировки типизированных файлов. Или единственный способ - это с помощью указателя представлять фаил, как массив и использовать приведенные выше сортировки |
![]() ![]() |
| andriano |
16.12.2007 15:40
Сообщение
#2
|
|
Гуру ![]() ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 1 168 Пол: Мужской Реальное имя: Сергей Андрианов Репутация: 28 |
Наилучшего алгоритма вообще в природе не существует. Могут быть наилучшие в каком-то конкретном случае.
Непонятно, что такое безазмерный файл. Если допорлнительые файлы использовать нельзя, то сортировать можно, естественно, только в оперативной памяти. Т.е.: 1. Считываешь файл. 2. Сортируешь. 3. Записываешь. Можно, конечно, использовать memory-mapped file, но вряд ли это чем-либо удобнее. И еще: если объем файла больше объема виртуальной памяти, то считать файл в память, разумеется, не получится. |
| Lapp |
16.12.2007 15:41
Сообщение
#3
|
![]() Уникум ![]() ![]() ![]() ![]() ![]() ![]() ![]() Группа: Модераторы Сообщений: 6 823 Пол: Мужской Реальное имя: Лопáрь (Андрей) Репутация: 159 |
с помощью указателя представлять фаил, как массив и использовать приведенные выше сортировки Указатели тут ни при чем. Используй процедуру Seek. В остальном - да, аналогично массивами. Другой вопрос, какой метод будет более эффективен именно для файлов.. Добавлено через 1 мин. Если допорлнительые файлы использовать нельзя, то сортировать можно, естественно, только в оперативной памяти. -------------------- я - ветер, я северный холодный ветер
я час расставанья, я год возвращенья домой |
| andriano |
16.12.2007 15:47
Сообщение
#4
|
|
Гуру ![]() ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 1 168 Пол: Мужской Реальное имя: Сергей Андрианов Репутация: 28 |
|
| Lapp |
16.12.2007 16:07
Сообщение
#5
|
![]() Уникум ![]() ![]() ![]() ![]() ![]() ![]() ![]() Группа: Модераторы Сообщений: 6 823 Пол: Мужской Реальное имя: Лопáрь (Андрей) Репутация: 159 |
"если нельзя, но очень хочется, то можно", но сколько времени это займет? Ответ должен соответствовать вопросу. Откуда ты знаешь - может, файл в на устройстве в оперативной памяти? Насчет скорости ты можешь предостеречь, если хочешь, но сначала - дай правильный ответ на поставленный вопрос. -------------------- я - ветер, я северный холодный ветер
я час расставанья, я год возвращенья домой |
| andriano |
16.12.2007 16:29
Сообщение
#6
|
|
Гуру ![]() ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 1 168 Пол: Мужской Реальное имя: Сергей Андрианов Репутация: 28 |
Все правильно - недостаток дидактической практики: решения, которые я считаю крайне неэффективными, отбрасываются на уровне подсознания - "этого делать нельзя, и точка!"
|
![]() ![]() |
|
Текстовая версия | 15.11.2025 7:34 |