69696

Отримання частини масиву

Лекция

Информатика, кибернетика и программирование

Дана функція повертає частину вказаного масиву, починаючи з вказаного зсуву від початку масиву. Вибірка елементів здійснюється підряд. Довжина результуючого масиву задається параметром Довжина, який є необов’язковим. Якщо цей параметр не вказаний, то вибірка елементів здійснюється до кінця початкового масиву.

Украинкский

2014-10-08

48.5 KB

0 чел.

Тема 16: Отримання частини масиву

Для отримання частини масиву використовується функція array_slice(). Їй потрібно передати три параметри:

| ім'я початкового масиву, з якого вибиратимуться елементи;

зсув від початку масиву, тобто скільки елементів від початку
масиву треба пропустити перед початком вибірки;

довжина, тобто кількість елементів, яку потрібно вибрати з
початкового масиву.

Дана функція повертає частину вказаного масиву, починаючи з вказаного зсуву від початку масиву. Вибірка елементів здійснюється підряд. Довжина результуючого масиву задається параметром Довжина, який є необов'язковим. Якщо цей параметр не вказаний, то вибірка елементів здійснюється до кінця початкового масиву.

Ось невеликі приклади:

$А =  array(xox,   ror,   tot,   pop,   mom);   //  задаємо початковий масив

$В   =   array_slice($A,2); // отримуємо   масив   $В,

// у   якому   містяться

// всі   елементи масиву   $А,

// починаючи з третьої  позиції

// (т.к.   два   треба   пропустити).

// Таким чином,   масив   $В

// міститиме   елементи

// tot,   pop,   mom.

$В  =   array_slice($A,0,2); // Отримуємо масив   $В,   у   якому

// містяться  два  елементи

// масиву   $А,   починаючи з першого

// (т.к.   треба  пропустити   0

// елементів).   Таким чином

// масив   $В  міститиме

// елементи     xox,   ror.

Параметри зсув і довжина можуть бути негативними — в цьому випадку відлік проводиться від кінця масиву:

$В   =   array_slice($A,2,-l); //   отримуємо   масив   $В,

//   що складається  з   елементів   tot, //   pop.

Функція array_spIice() схожа на функцію array_slice(). Їй потрібно передати ще один додатковий параметр — масив (назвемо його $R). Як і array_slice(), функція array_splice() повертає масив вказаної довжини, починаючи із зсуву $offset, але і замінює передані нею елементи на вміст масиву $R. B принципі, замість масиву $R можна вказати звичайне рядкове значення. Приклад:

$А   =   array("Audi","Mercedes", "Toyota", "Honda", "Renault"); array_splice($A,l,count($А),    "BMW"); //   $А   =   array("Audi","BMW");

7.8. Додавання і видалення елементів масиву

Додавання в кінець масиву

Раніше ми з вами освоїли простий спосіб додавання нових елементів в масив, здійснюваний за допомогою оператора []. Проте в останніх версіях PHP (починаючи з 4) передбачена функція array_push(), яка додає елементи в кінець масиву так само, як і оператора []. Наприклад, наступні два оператори аналогічні:

$А[]    =   5; array_push($А,5);

Може виникнути справедливе питання: «А навіщо потрібно два однакові способи робити одне і те ж?». Відповідь полягає в зручності. Якщо необхідно додати один елемент в масив (як в приведеному вище прикладі), то зручніше використовувати оператора []. Використання ж функції array_push() виправдовує себе тоді, коли нам потрібно додати в кінець масиву декілька нових елементів. Наприклад:

$А[] = 5;

$А[] = 7;

$А[] = 9;

$А[] = 10;

$А[] = 15;

Натомість можна записати:

array_push($A,    5,7,9,10,15);

Примітка.

Функція array_push(), крім всього іншого, повертає новий розмір масиву. Тобто, якщо крім того, щоб додати нові елементи в масив, вам потрібно дізнатися і його нову довжину, то можна записати $D = array_push($A, 5, 7, 9, 10, 15). Таким чином, нова довжина масиву буде привласнена змінною $D.

Видалення останнього елементу списку

Функція array_pop() протилежна функції array_push(). Вона «виштовхує» вершину списку (останній елемент списку). Іншими словами, функція array_pop() повертає значення останнього елементу масиву і видаляє його із списку.

Функції array_pop() потрібно передати всього один параметр — ім'я масиву (списку):

$A = array(xox, ror, tot pop, mom);

$T=array_pop($A);      // змінній $Т привласнили

// значення mom, а масив $A

// позбувся цього останнього

// елементу і тепер складається з

// елементів xox, ror, tot, pop.

array pop($A);         // масив $А ще раз позбувся останнього

// елементу і тепер

// складається з елементів xox, ror, tot.

Примітка.

За допомогою функцій array_push() і array_pop() ми можемо будувати структури LIFO (Last In First Out — «останній увійшов — перший вийшов»), що нагадують стік. Структури типу стек широко застосовуються в програмуванні. Класичне застосування стека — зворотний польський запис, який використовується для розбору арифметичних виразів і обчислення їх значення.

Додавання в початок списку. Видалення першого елементу списку

Функції array_unshift() і array_shift() схожі на функції array_push()

і array_pop(), але тільки працюють не з кінцем списку, а з його початком. Функція array_unshift() додає елементи в початок списку, а функція array_shift() повертає значення першого елементу списку і видаляє його із списку (видаляє «голову» списку):

$А = array(3,4,5) ;

array_unshift($A, 1,2);   // отримуємо $А = array(l,2,3,4,5)

array_shift($A);         // отримуємо $А = array(2,3,4,5);

Примітка.

Функції array_unshift() і array_shift() корисно використовувати, якщо ви хочете побудувати чергу типа FIFO (First In First Out — «перший увійшов — перший вийшов»). Черга необхідна для послідовної обробки елементів масиву. Стік і черга в мовах З і Pascal є основними динамічними структурами. Поськолькудліна масивів в PHP обмежена вільними системними ресурсами, потреба в стеку і черзі зникає. Функції для організації стека і черги були написані виключно для зручності програміста — раптом ви, програмуючи на З, звикли працювати саме із стеком або з чергою?

Функція array_unique()

Функція array_unique() призначена для витягання унікальних значень масиву разом з ключами цих значень. Ось приклад застосування цієї функції:

$Arr = array("a"=>"AAA","b"="BBB","c","d","e"="BBB", "d");

$Unique_Arr = array_unique($Arr);

// ?UniqueArr = array("a"=>"AAA","b"="BBB","c","d");


 

А также другие работы, которые могут Вас заинтересовать

49138. МИКРОПРОЦЕССОРНАЯ СИСТЕМА УПРАВЛЕНИЯ 755.5 KB
  Конечный датчик служит для сигнализации системе о том, что она максимально переместилась от нулевого положения или находится в нулевом положении. В качестве конечного датчика можно выбрать реле (такие как поляризованные, герметизированные и их виды: шариковые, плунжерные и т.д.) В данной системе требуется один конечный датчик (датчик нулевой позиции)
49139. Трехзвенный Г-образный фильтр верхних частот 667 KB
  Переходная харатеристика Техническое задание Электрическая принципиальная схема Задание: Расчет АЧХ ФЧХ и переходной характеристики трехзвенного Гобразного фильтра. Расчет Рис.
49140. Полосовой фильтр 24.46 MB
  Получить Амплетудно–Частотную, Фаза –Частотную характеристики, переходную характеристику и построить их графики Задание Расчет стационарных характеристик цепи Таблицы и графики АЧХ и ФЧХ...
49141. ИСПОЛЬЗОВАНИЕ АКУСТООПТИЧЕСКОГО ЭФФЕКТА ДЛЯ ИЗМЕРЕНИЯ ФИЗИЧЕСКИХ ВЕЛИЧИН 2.4 MB
  Широкий спектр применения акустооптических приборов возможен благодаря многогранности акустооптического эффекта с помощью которого можно эффективно манипулировать всеми параметрами оптической волны. Усиление слабых акустических волн а также их генерация под действием мощной оптической волны фото-акустические или опто-акустические явления. Под воздействием мощной волны ультразвука в жидкости может наблюдаться в свою очередь генерация оптической волны так называемая соно-люминесценция. Для плоской монохроматической акустической волны...
49143. Инфракрасная спектроскопия и метрологическое обеспечение 1.17 MB
  Содержание пояснительной записки курсовой работы проекта: Инфракрасная спектроскопия Икспектры поглощения органических соединений Инфракрасное излучение и колебания молекул Гармонические и ангармонические колебания Колебания многоатомных молекул Оборудование для инфракрасной спектроскопии Основные области инфракрасного спектра Инфракрасный спектр Характеристические частоты групп 4. Нефедов...
49144. ФИНАНСЫ ОРГАНИЗАЦИЙ. МЕТОДИЧЕСКИЕ УКАЗАНИЯ 611 KB
  Теоретические методические и нормативно-правовые аспекты изучения оборотных средств организации предприятия Сущность состав и классификация оборотных средств предприятия Обзор нормативно-правовой базы в сфере учета и анализа оборотных средств Аналитический обзор состояния оборотных средств российских предприятий...
49145. IDEF–моделирование мандатного (полномочного) разграничения доступа 763.5 KB
  Суть ее такова что в СЗИ вводятся уровни безопасности или иначе уровни секретности. Работники с самым высоким уровнем безопасности могут работать с документами самой высокой степени секретности. В любой компьютерной системе которая предоставляется для множества пользователей необходимо тщательно продумать политику безопасности для обеспечения трех основных концепций защиты информации: конфиденциальность информации целостность информации доступность информации; Основу для установки анализа и применения политик безопасности в...