Форум программистов, компьютерный форум, киберфорум
PHP
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.54/13: Рейтинг темы: голосов - 13, средняя оценка - 4.54
Автор FAQ
 Аватар для insideone
3687 / 964 / 114
Регистрация: 10.01.2010
Сообщений: 2,550

PHP-задачки: Сортировка предложений по длине

31.01.2012, 11:36. Показов 2416. Ответов 5

Студворк — интернет-сервис помощи студентам
Продолжаю постить небольшие задачки\головоломки на PHP.
Решать нужно без применения циклов, в т.ч. скрытых.
Т.е. решение не должно содержать своих функций\методов, только вызовы стандартных функций.


Прелюдия: Есть текст в $textBase разделенный точками. Мы получаем предложения $arSentences с помощью explode.
Задача: Нужно отсортировать $arSentences по возрастанию длины строки элемента. Т.е. сделать так чтобы этот массив вначале содержал короткие предложения, а в конце - самые длинные.

Спойлер решения
PHP
1
2
3
4
$arSentences = explode('.', $textBase);
$arSentencesLen = array_map('strlen', $arSentences);
$arSentencesCombine = array_combine($arSentences, $arSentencesLen);
asort($arSentencesCombine);


Кто ещё как решит?
1
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
31.01.2012, 11:36
Ответы с готовыми решениями:

Сортировка по длине
Помогите пожалуйста. дана строка(слова разделены пробелом) нужно вывести их в алфавитном порядке и вывести по мере укорачивания...

Сортировка по длине
На вход подается некоторое количество векторов R2, векторов R3 и отрезков R3. Отсортировать и вывести их по возрастанию длин. Помогите,...

Сортировка по длине
Отсортируйте введённые строки по возрастанию их длины, строки одинаковой длины при этом должны быть отсортированы по возрастанию в...

5
Автор FAQ
 Аватар для insideone
3687 / 964 / 114
Регистрация: 10.01.2010
Сообщений: 2,550
08.02.2012, 21:16  [ТС]
Надо сказать решение не универсальное, в $arSentences не должно быть повторяющихся элементов, иначе они не смогут быть уникальными ключами.
0
65 / 65 / 6
Регистрация: 22.09.2010
Сообщений: 182
11.02.2012, 03:39
PHP
1
2
3
4
5
6
function cmp($a, $b) 
{
    return (strlen($a) == strlen($b)) ? 0 : (strlen($a) < strlen($b)) ? -1 : 1;
}
$arSentences = explode('.', $textBase);
usort($arSentences, "cmp");
0
 Аватар для Vovan-VE
13210 / 6599 / 1041
Регистрация: 10.01.2008
Сообщений: 15,069
11.02.2012, 06:54
Цитата Сообщение от Great-Antique Посмотреть сообщение
PHP
1
2
3
4
5
6
function cmp($a, $b) 
{
 return (strlen($a) == strlen($b)) ? 0 : (strlen($a) < strlen($b)) ? -1 : 1;
}
$arSentences = explode('.', $textBase);
usort($arSentences, "cmp");
Это ж то же самое, что
PHP
1
usort($arSentences, "strlen");
1
Автор FAQ
 Аватар для insideone
3687 / 964 / 114
Регистрация: 10.01.2010
Сообщений: 2,550
11.02.2012, 12:47  [ТС]
Цитата Сообщение от Vovan-VE Посмотреть сообщение
Это ж то же самое, что
Это как так? Функция обратного вызова принимает 2 аргумента, а strlen - всего 1!

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
<?
 
$arSentences = array(
    'Продолжаю постить небольшие задачки\головоломки на PHP.',
    'Решать нужно без применения циклов, в т.ч. скрытых.',
    'Т.е. решение не должно содержать своих функций\методов, только вызовы стандартных функций.',
);
 
usort($arSentences, 'strlen');
 
echo '<pre>'.print_r($arSentences,1).'</pre>';
 
?>
С mb* расширением вообще работать точно не будет, потому что функция думает что вторым аргументом ей передают кодировку

Warning: mb_strlen() [function.mb-strlen]: Unknown encoding "Продолжаю постить небольшие задачки\головоломки на PHP." in D:\be\www\exp.php on line 9

Warning: mb_strlen() [function.mb-strlen]: Unknown encoding "Решать нужно без применения циклов, в т.ч. скрытых." in D:\be\www\exp.php on line 9
Array
(
[0] => Т.е. решение не должно содержать своих функций\методов, только вызовы стандартных функций.
[1] => Решать нужно без применения циклов, в т.ч. скрытых.
[2] => Продолжаю постить небольшие задачки\головоломки на PHP.
)


Great-Antique, смысл решать задачи не читая правил?
1
11.02.2012, 17:07

Не по теме:

Цитата Сообщение от insideone Посмотреть сообщение
Это как так? Функция обратного вызова принимает 2 аргумента, а strlen - всего 1!
М-да, это я здорово наврал. :D

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
11.02.2012, 17:07
Помогаю со студенческими работами здесь

Сортировка слов по длине
задан текст. выполнить сортировку этих слов, расположив их в порядке увеличения количества букв в словах

Сортировка слов по их длине
Ввести строку. На печать выдать новую строку в которой все слова расположены в порядке возрастания длин слов.

Сортировка абзацев по длине
Есть задание написать макроси для сортировки абзацов по длине или по алфавиту, по алфавиту изи сделал, а вот с длиной никак. Хто в етом...

Сортировка рёбер по длине
Ориентированный взвешенный граф задан перечнем дуг (ориентированных рёбер). Отсортировать эти дуги по возрастанию длин, сохранив (в...

Сортировка слов по длине
На языке ассемблер в компиляторе TASM, нужно написать программу: Дано предложение, состоящее из нескольких слов, разделенных пробелами....


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
YAFU@home — распределённые вычисления для математики. На CPU
Programma_Boinc 20.01.2026
YAFU@home — распределённые вычисления для математики. На CPU YAFU@home — это BOINC-проект, который занимается факторизацией больших чисел и исследованием aliquot-последовательностей. Звучит. . .
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru