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");


 

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

28631. Структурный тип - Массив 48.5 KB
  Понятие массива в Паскале. Описание массивов и доступ к элементам массива. Понятие массива в Паскале. Идея массива состоит в том чтобы объединить в одно целое фиксированное количество элементов одного и того же типа.
28632. Структурный тип - Строка 37 KB
  m] of char; где: m максимальная длина строки число диапазона 0 . Строки длины до 255 соответствуют типу string без указания длины строки. Нулевая позиция строки является специальной позицией в которой хранится текущая длина строки код ASCII представляющий длину строки. Доступ к компоненту строки символу строки осуществляется также как к элементу массива т.
28633. Структурный тип - Множество 45.5 KB
  Понятие о типе Множество в Турбо Паскале. Описание типа Множество и константымножества . Понятие о типе Множество в Турбо Паскале.
28634. Структурный тип - Запись 49.5 KB
  Запись как объединение неоднородных данных. Запись как объединение неоднородных данных. Объединение таких данных общий структурный типанкета затруднительно сделать в рамках массива или множества. Этот структурный тип специально введен для объединения любого конечного числа неоднородных данных.
28635. Структурный тип - Файл 48 KB
  Концепция файла в Паскале. Стандартные процедуры и функции работы с файлами. Особенности работы с типизированными файлами. Концепция файла в Паскале.
28636. Динамическая память и указатели 54 KB
  Все рассмотренные ранее типы данных (кроме типа file) представляли статические структуры. Память выделялась под переменные этих типов до выполнения программы, а размер выделяемой памяти определялся по описаниям соответствующих переменных (например, для переменной типа byte выделялся 1 байт оперативной памяти). Такая память является статической, поскольку её размер не может изменяться при выполнении программы.
28637. Базисные конструкции языка 89.5 KB
  Структура программы. Для этого в структуре программы предусмотрен раздел описаний. Необходимо научиться читать программы понимая смысл написанного а затем и писать собственные пусть вначале и несложные программы. научиться читать программы .
28638. Простые операторы и программы с линейной структурой 61.5 KB
  Простые операторы ввода и вывода. Простые операторы ввода и вывода. Эти операторы Турбо Паскаля обеспечивают простейшие формы ввода с клавиатуры и вывода на экран дисплея в текстовом режиме. К простым операторам ввода и вывода относятся операторы read readln write writeln реализующие так называемый потоковый вводвывод при котором ввод и вывод рассматриваются как непрерывный поток символов и строк протекающий через экран дисплея.
28639. Процедуры и функции в Турбо Паскале 90 KB
  Концепция подпрограммы в Турбо Паскале. Концепция подпрограммы в Турбо Паскале. Понятие подпрограммы одно из фундаментальных понятий в программировании возникшее фактически вместе с понятием программы. Одна подпрограмма может включать в себя другие подпрограммы и т.