Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.02.26;
Скачать: CL | DM;

Вниз

Множества. Написание оптимизированного кода   Найти похожие ветки 

 
CMOS ©   (2006-02-05 20:51) [0]

Что такое множество(Set of ..) в Delphi и Pascal? В С++ и в VB их нет. Скорее всего и в Delphi его тоже нет. Наверно это просто массив или, в лучшем случае, дерево поиска.
Что лучше, c т.з. написания оптимизированного кода?
if (x>=10) and (x<=20) then...
или
if x in [10..20] then...


 
Anatoly Podgoretsky ©   (2006-02-05 21:06) [1]

Множество это тоже самое, что и множество в математике, автор очень бережно к этому отнешься.
Множесто это необязательно числа.


 
begin...end ©   (2006-02-05 21:28) [2]

> CMOS ©   (05.02.06 20:51)

> Что такое множество(Set of ..) в Delphi

Если это -- константа или переменная, объявленная как set of ..., то оно представляет из себя битовый массив размером [(мощность_базового_типа div 8) + 1] байт. Проверка на вхождение в множество делается командой BT.

А вот для проверок типа if x in [10..20] никакого массива не создаётся, и они производятся путём арифметических операций (сложение/вычитание) с последующим анализом флагов процессора.

> Что лучше, c т.з. написания оптимизированного кода?

"Практика -- критерий истины" (с)


 
begin...end ©   (2006-02-05 21:38) [3]

К [2]:

> Проверка на вхождение в множество делается командой BT.

...или TEST.


 
Германн ©   (2006-02-06 01:46) [4]


> Что лучше, c т.з. написания оптимизированного кода?
> if (x>=10) and (x<=20) then...
> или
> if x in [10..20] then...


Добавлю ещё, что первый вариант пройдет всегда, а второй - только для целочисленных типов.


 
CMOS ©   (2006-02-07 14:20) [5]

Динамично ли множество?
Сколько оно будет занимать памяти если в нем содержится только 1 элемент, 10 эл-тов, 255 эл-тов?


 
evvcom ©   (2006-02-07 14:33) [6]


> Динамично ли множество?

Статично.

> Сколько оно будет занимать памяти

См. [2]


 
Digitman ©   (2006-02-07 14:34) [7]


> CMOS ©   (07.02.06 14:20) [5]


Все это зависит от конкретного компилятора/интерпретатора.


 
Loginov Dmitry ©   (2006-02-07 20:10) [8]


> Что лучше, c т.з. написания оптимизированного кода?


Насчет чисел не проверял, а вот если выполняется проверка символов в строке, то вариант S[i] in ["a".."z" и т.п.] работает быстрее, чем с оператором if. Подозреваю, что и с числами будет то же самое.



Страницы: 1 вся ветка

Текущий архив: 2006.02.26;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.235 c
4-1134025564
leonidus
2005-12-08 10:06
2006.02.26
Не получается удалить иконку приложения из Atl+Tab


15-1139056312
ZbarKiy
2006-02-04 15:31
2006.02.26
Исходники архиваторов?


2-1139595605
13
2006-02-10 21:20
2006.02.26
удалить веделенный текст


2-1139569245
Enki
2006-02-10 14:00
2006.02.26
Картинки и текст в одном


15-1138860173
Ega23
2006-02-02 09:02
2006.02.26
С Днём рождения! 2 февраля