Мы уже знаем, как сортировать массивы с помощью `sort()` и `rsort()`, но у них есть важный недостаток: они сбрасывают ключи. Это проблема для ассоциативных массивов, где ключи несут важную информацию.
Здесь на сцену выходят функции `asort()` и `arsort()`. Буква "а" в названии означает "associative" и говорит о главном: эти функции сохраняют связь между ключом и значением . `asort()` сортирует массив по значениям в порядке возрастания, сохраняя ключи. `arsort()` делает то же самое, но в обратном (reverse) порядке. Этот тренажер научит вас пользоваться этими незаменимыми инструментами для работы с ассоциативными данными.
- Модуль 1: Основы синтаксиса PHP
- Модуль 2: Переменные и типы данных
- Модуль 3: Операторы
- Модуль 4: Условные конструкции
- Модуль 5: Циклы
- Модуль 6: Массивы
- Индексированные массивы.
- Ассоциативные массивы.
- Многомерные массивы.
- Добавление элементов в массив.
- Удаление элементов из массива.
- Функция count().
- Функция array_push() и array_pop().
- Функция array_shift() и array_unshift().
- Функция array_merge().
- Функция array_slice().
- Функция array_splice().
- Функция in_array().
- Функция array_search().
- Функция array_keys() и array_values().
- Функция array_unique().
- Функция array_reverse().
- Сортировка: sort(), rsort().
- Сортировка: asort(), arsort().
- Сортировка: ksort(), krsort().
- Функция array_map().
- Функция array_filter().
- Функция array_reduce().
- Функция array_walk().
- Функция array_column().
- Деструктуризация массивов.
- Модуль 7: Функции
- Объявление функций.
- Вызов функций.
- Параметры функций.
- Возврат значений return.
- Значения параметров по умолчанию.
- Передача по значению.
- Передача по ссылке.
- Переменное количество аргументов.
- Оператор распаковки ....
- Типизация параметров.
- Типизация возвращаемых значений.
- Nullable типы.
- Union типы (PHP 8).
- Именованные аргументы (PHP 8).
- Анонимные функции.
- Стрелочные функции.
- Замыкания и use.
- Рекурсивные функции.
- Глобальные переменные в функциях.
- Статические переменные в функциях.
- Модуль 8: Работа со строками
- Одинарные и двойные кавычки.
- Экранирование символов.
- Heredoc и Nowdoc синтаксис.
- Функция strlen().
- Функция substr().
- Функция str_replace().
- Функция strpos() и strrpos().
- Функция explode() и implode().
- Функция trim(), ltrim(), rtrim().
- Функция strtolower() и strtoupper().
- Функция ucfirst() и ucwords().
- Функция str_repeat().
- Модуль 9: Суперглобальные переменные
- Модуль 10: Работа с формами
- Модуль 11: Работа с файлами
- Модуль 12: Дата и время
- Модуль 13: Регулярные выражения
- Модуль 14: Сессии и Cookie
- Модуль 15: Include и Require
- Модуль 16: Объектно-ориентированное программирование
- Модуль 17: Пространства имен
- Модуль 18: Обработка ошибок и исключений
- Модуль 19: Работа с JSON и XML
- Модуль 20: Работа с базами данных MySQLi
- Модуль 21: PDO - PHP Data Objects
- Модуль 22: Composer и зависимости
- Модуль 23: cURL и HTTP запросы
- Модуль 24: REST API
- Модуль 25: Безопасность
- Модуль 26: Генераторы и итераторы
- Модуль 27: Reflection API
- Модуль 28: Работа с изображениями
- Модуль 29: Отправка email
- Модуль 30: Паттерны проектирования
- Модуль 31: Тестирование
- Модуль 32: Продвинутые возможности PHP 8+
Сортировка с сохранением ключей
Представим, что у нас есть массив с баллами студентов, где ключ — это имя, а значение — балл. Нам нужно отсортировать студентов по успеваемости от худшего к лучшему, не теряя их имена. Заполните пропуск, чтобы выполнить эту задачу.
<?php
$scores = [
'John' => 85,
'Jane' => 92,
'Peter' => 78
];
// Сортируем по баллам, сохраняя имена
input1S($scores);
print_r($scores);
?>Обратная сортировка с сохранением ключей
Теперь создадим рейтинг лучших студентов. Используя тот же массив, отсортируйте его по баллам в порядке убывания (от лучшего к худшему), сохранив при этом имена студентов (ключи). Впишите название нужной функции.
<?php
$scores = [
'John' => 85,
'Jane' => 92,
'Peter' => 78
];
// Сортируем для получения рейтинга
input1S($scores);
print_r($scores);
?>Результат работы asort()
Давайте проверим, как вы поняли принцип работы `asort()`. Перед вами ассоциативный массив с расстояниями до городов. Проанализируйте код и выберите, как будет выглядеть массив после сортировки.
<?php
$distances = [
'city_c' => 300,
'city_a' => 150,
'city_b' => 500
];
asort($distances);
print_r($distances);
?>Не та функция сортировки
Программист хотел отсортировать инвентарь по количеству, сохранив названия предметов. Но он использовал функцию `sort()`, которая сбросила все ключи. Исправьте название функции, чтобы код сохранял названия предметов (ключи).
<?php$inventory = ['Potion' => 10, 'Sword' => 1, 'Shield' => 1]; // Ошибка: sort() удалит ключи 'Potion', 'Sword', 'Shield'sort($inventory); print_r($inventory);?>Сортировка по убыванию: предскажите результат
Теперь ваша очередь. Перед вами массив возрастов. После применения `arsort()` массив изменится. Напишите в поле ответа, как именно будет выглядеть результат вывода `print_r()`. Будьте внимательны к ключам и значениям.
<?php
$ages = [
'John' => 30,
'Jane' => 45,
'Kate' => 22
];
arsort($ages);
print_r($ages);
?>Сборка скрипта для сортировки продуктов
Соберите из фрагментов PHP-скрипт. Цель: отсортировать массив продуктов по цене (значение) от самой дешевой к самой дорогой, сохранив артикулы (ключи). В наборе есть лишние и неверные строки.
$products = ['p003' => 25, 'p001' => 100, 'p002' => 50];asort($products);print_r($products);?><?php$sorted = asort($products);sort($products);Естественная сортировка с сохранением ключей
Представьте, что у вас есть версии продукта, и вам нужно их отсортировать. Обычная сортировка не справится с 'v10' и 'v2'. Используйте правильную функцию и флаг из банка, чтобы выполнить "естественную" сортировку с сохранением ключей.
<?php
$versions = [
'release1' => 'v10.1',
'release2' => 'v2.5',
'release3' => 'v1.9'
];
input1S($versions, input2S);
print_r($versions);
?>