Последние записи
- TChromium (CEF3), сохранение изображений
- Как в Delphi XE обнулить таймер?
- Изменить цвет шрифта TextBox на форме
- Ресайз PNG без потери прозрачности
- Вывод на печать графического файла
- Взаимодействие через командную строку
- Перенести программу из Delphi в Lazarus
- Определить текущую ОС
- Автоматическая смена языка (раскладки клавиатуры)
- Сравнение языков на массивах. Часть 2
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
26th
Сен
Функции для работы с динамическими массивами
Posted by Chas under Delphi
Я в инете нашёл несколько функций для работы с дин.массивами, но использовать их почему-то не удаётся. Подскажите, что с ними делать, может для них надо подключить какую-то библиотеку или ещё чего?
Suny-o
Библиотека QuickSortStr.rar (GPL2) для быстрой сортировки динамического массива строк, а также добавления и удаления элементов в одномерном и двухмерном динамическом массиве строк.
Архив содержит программу пример.
Причины создания библиотеки:
Ограниченность числа элементов TStringList=129391
Специфичность алгоритма сортировки TStringList — одна буква z ставиться после длинного слова zoom т.е. zoom,z.
Пользоваться функциями сортировки очень просто — пример:
uses
QuickSortStr;
{Type
dinarr=array of string;
dinarr2=array of array of string;
Определен в QuickSortStr.pas}
var
strlist1:dinarr;
strlist2:dinarr2;
//alfavit - строка символов упорядоченная по вашему усмотрению
//Должна содержать все символы которые есть в массиве
//Быстрая сортировка по алфавиту примерно в 5 раз долше
//Чем приведенная ниже ускоренная сортировка по ASCII
//Примечание: критично для массива строк >50000
//Время сортировки для 50000 строк ~1 мин.
QuickSortRNDauto(alfavit,0,length(strlist1)-1,3,strlist1);
//Самый показательный пример
//Сортировка одномерного динамического массива строк strlist1
//от начала до конца
//Примечание: на месте 3 могут быть цифры от 1 до 10 и более
//1.Это трехкратный повтор внутренней процедуры быстрой сортировки
//2.И проверка отсортированности массива, если нет идем на 1
QuickSortFastRNDauto(0,length(strlist1)-1,3,strlist1);
//Тоже самое для подмассива двухмерного массива с индексом 1
QuickSort2FastRNDauto(1,0,length(strlist2[1])-1,3,strlist2);
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
пеллетные котлы
Пеллетный котел Emtas
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)