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

Вниз

Поиск в файле   Найти похожие ветки 

 
SinnerPro   (2003-01-19 09:52) [0]

Вот. В общем дан файл, размером ~2,5-3 Mb. Надо, из него вытянуть количество последовательностей из 3х определенных букв. Файл содержит абсолютно все символы. Расстояние между последовательностями разное, в среднем от 5000 до 45000 символов. Желательно чтобы это происходило достаточно быстро, медленно я сам сделать могу ;).


 
Song ©   (2003-01-19 10:39) [1]

BlockRead+цикл будет вполне быстро
или через наследнные классы от TStream, если только чтение нужно.


 
Романов Р.В. ©   (2003-01-19 10:47) [2]

Читай файл в буфер целиком или кусками. Ищи последовательность в цикле.


 
SinnerPro   (2003-01-19 11:07) [3]

Song: Романов Р.В:

Да я пробывал, все равно тормазно как-то... ну если никак подругому нельзя, то ладно


 
Романов Р.В. ©   (2003-01-19 11:54) [4]

Можно несколько ускорить процесс поиска если проверять не все байты, а через 3. Для этого нужно получить маску.
b: Byte;
...
b :=(Ord("A") or Ord("G") or Ord("T")) xor $FF;

Сравниваешь каждый третий байт с этой маской
if (CurentByte and b) = 0 then
// Более точная проверка в окрестностях этого байта.

При некоторых условиях способ может оказаться медленнее прямого перебора.



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

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

Наверх




Память: 0.47 MB
Время: 0.021 c
14-87141
qwert-AP
2003-01-10 10:41
2003.01.27
Документация по проекту


1-86820
diks
2003-01-15 22:10
2003.01.27
Radiobutton


14-87045
polizei
2003-01-11 08:40
2003.01.27
У К А ЗА ТЕ Л И !


6-87012
NickolayLI
2002-12-02 13:02
2003.01.27
BroadCast (эксперемент)


3-86654
GeRon
2003-01-08 09:06
2003.01.27
Отображение поля Boolean в DBGrid