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

Вниз

Дин. массивы.   Найти похожие ветки 

 
Ш-К   (2004-02-26 13:51) [0]

Как удалить элемент из динамического массива?
Строить временный массив, заполнять его в цикле, а потом присваивать исходному? Или есть другие методы?


 
Тимохов ©   (2004-02-26 13:55) [1]

например, нужно удалить элемент i
меремещаем i+1 на место i, i+2 на место i+1, и т.д.
уменьшаем на единицу длину массива.

Если очень нужна скорость можно через move это сделать.


 
Erik ©   (2004-02-26 15:06) [2]

Только осторожно, особенно если у тебя в масиве находятся строки. А если длиные строки, то Move тебе непоможет.


 
Тимохов ©   (2004-02-26 15:13) [3]

поможет move+finalize+fillchar.


 
Ш-К   (2004-02-26 15:51) [4]

Массивы типа integer. Вставку/удаление сделал через циклы и временный массив.


 
wisekaa ©   (2004-02-26 15:55) [5]


> Массивы типа integer.

Используй лучьше TList, в какойто книге есть даже пример как вывести из TList -> TIntegerList. В работе будет гораздо удобнее.


 
PVOzerski ©   (2004-02-26 16:03) [6]

Здесь в принципе возможно 2 подхода (остальное - варианты реализации): либо делать много переприсвений (сдвиг), либо работать через связные списки. Во 2-м случае мы платим 4-8 байтами за каждый элемент и невозможностью быстро, по индексу, добраться до интересующего элемента. Зато выбросить или вставить элемент можно, не трогая большинство других и не выделяя временные блоки памяти. Есть еще один вариант: обозначать ненужные элементы каким-нибудь флагом и игнорировать их, скажем, при работе цикла.


 
Serginio666   (2004-02-26 16:33) [7]

Move


 
Тимохов ©   (2004-02-26 16:39) [8]


> wisekaa © (26.02.04 15:55) [5]

Для критичных по времени операций дин массивы лучше, если в них использовать тот же подход, что и в TList, т.е. Count+Capacity.
Это объясняется тем, что для доступа к элементам не нужен вызов метода. А выделение памяти в обоих случаях делается через штатных менеджер памяти.
Если же время не критично, то с вами полностью согласен - TList, это хорошо.


 
wisekaa ©   (2004-02-26 16:45) [9]


> [8] Тимохов © (26.02.04 16:39)

С этим я согласен полностью



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

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

Наверх




Память: 0.48 MB
Время: 0.017 c
14-25907
Grugan
2004-02-10 19:32
2004.03.09
WinInet функции


6-25835
redacid
2004-01-04 01:56
2004.03.09
Разрешение IP Address в имя на Win 98 SE


14-25936
Soft
2004-02-15 00:19
2004.03.09
Голубая кровь!!!


1-25784
din
2004-02-27 10:18
2004.03.09
отчет в Excel


1-25772
Tatyana
2004-02-26 14:21
2004.03.09
#0, AccessViolation