Форум программистов, компьютерный форум, киберфорум
PHP
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
0 / 0 / 0
Регистрация: 19.01.2010
Сообщений: 62

Оптимизация PHP кода,есть скрипт который обрабатывает текст,аналоги работают за секунды,мой выполняется шесть минут

12.02.2010, 14:04. Показов 1473. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Скрипт:нужно узнать какая из букв в тексте расположена первее всех,и вывести её номер в этом тексте,
и делать это всё в цикле пока пока текст не закончится.В этом скрипте всё работает:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
$razd=array('а','г','к','з','м','и');
$kreo=100000;
$n=0;
while (isset($razd[$n])){
$kre=strpos($text,$razd[$n]);
$kre++;
if ($kre==true and $kre<=$kreo){
$kreo=$kre;
$nr=$n;
};
$n++;
.
.
.
.
.
$text=substr($text,0,$kreo)
};
Но он выполняется шесть минут для одного текста,а время в этом скрипте критично ,я догадываюсь что задачу можно выполнить быстрее
во много раз,так как аналоги таких программ работают за секунды.Может кто-нибудь знает как можно
оптимизировать максимально этот код или выполнить его на другой платформе типа СИ.Буду очень благодарен тому кто поможет.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.02.2010, 14:04
Ответы с готовыми решениями:

Оптимизация кода проекта, где есть множество форм, на которых выполняется одно действие
Приветствую! Гуру программирования, подскажите как оптимизировать код проекта. Объясняю суть. В проекте есть множество форм, на которых...

Можно ли делать include php ,при котором если в загружаемом файле есть ошибки,то чтобы необваливался весь скрипт в который загружается другой скрипт?
Можно ли делать include php ,при котором если в загружаемом файле есть ошибки,то чтобы необваливался весь скрипт в который загружается...

Мой любимый Visual Basic 6.0 есть аналоги?
Когда-то в далеком 2000 году писал курсовик на VB6. Поэтому экстерном изучил основы и быстренько написал программу. Потом еще 2-3 года...

4
Программист
 Аватар для motakuji
107 / 111 / 9
Регистрация: 27.09.2009
Сообщений: 331
12.02.2010, 15:53
как я понял тебе нужно узначать какая из букв встретилась первой ? и всё?
1
0 / 0 / 0
Регистрация: 19.01.2010
Сообщений: 62
12.02.2010, 16:22  [ТС]
Цитата Сообщение от motakuji Посмотреть сообщение
как я понял тебе нужно узначать какая из букв встретилась первой ? и всё?
Да именно это,почему strpos не поддерживает регулярные выражения ((,так этот скрипт просматривает весь текст ищет букву (а может её и не найти) апомиает её положение,потом ищет другую букву и так для всех,вот если бы он сразу искал с первого раза букву без цикла,это было бы классно
0
 Аватар для ostgals
886 / 681 / 101
Регистрация: 23.01.2009
Сообщений: 1,582
12.02.2010, 16:41
PHP
1
2
3
4
5
6
7
8
$razd = array('а','г','к','з','м','и');
 
$r = implode('', $razd);
$i_max = strlen($text);
 
for ($i = 0; $i < $i_max, $c = $text[$i]; $i++) if (strpos($r, $c) !== false) $n[] = $i;
 
print_r($n);
Можно и регуляркой.. Но будет медленнее.

Добавлено через 4 минуты
Вариант с регуляркой:

PHP
1
2
3
preg_match_all('/['.$r.']/si', $text, $matches, PREG_OFFSET_CAPTURE);
 
print_r($matches[0]);
1
Программист
 Аватар для motakuji
107 / 111 / 9
Регистрация: 27.09.2009
Сообщений: 331
12.02.2010, 16:53
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
$str='брукапрыфсззмсмжюьбитэхщшопаьдмсиьээфывмьчсорэжроэ';
$razd=array('г','к','з','м','и');
foreach ($razd as $val){
    $tmp_arr[$val]=strpos($str,$val);
    $tmp=$tmp_arr[$val];
}
 
foreach ($tmp_arr as $key=>$val){
    if (!is_integer($val)) continue ;
    if ($val<$tmp){
        $tmp=$val;
        $first_let=$key;
    }
}
print 'Первой встретилась буква <b>'.$first_let.'</b> на позиции '.$tmp;
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.02.2010, 16:53
Помогаю со студенческими работами здесь

Php не обрабатывает скрипт в открываемом файле
Здарова всем. Описание вопроса: 1. Есть 2 файла, в 1 лежит скрипт, открывающий 2 файл и выводящий из него все данные. 1 файл...

Нyжна оптимизация кода : выполняется лишние разы и не доконца
вот код : static int _handle_amhcheck_command(t_connection * c, char const *text) { t_elem const * curr; t_connection *...

Перевод времени из минут и секунды в секунды
Всем привет! Помогите с контрольными по С++, Я пока не совсем понимаю этот язык. Заранее Спасибо! 4.12 Написать программу, которая...

Как узнать скрипт который выполняется при нажатии кнопки?
Собственно сабж в заголовке К примеру через firebug

PHP не выполняется скрипт
Здравствуйте. Начинаю изучать PHP и пробую писать скрипты. Написал простейший скрипт: &lt;?php $name=&quot;senek&quot;; ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru