Как создать многомерный массив js
Перейти к содержимому

Как создать многомерный массив js

  • автор:

Как создать n-мерный (многомерный) массив на JavaScript?

как в JavaScript заносить массив в многомерный массив, без обертывания в кавычки? Т.е. есть массив — в него нужно засунуть еще 3 массива с 3мя елементами в каждом. В конечном счете мне нужно получить многомерный массив такого вида:

var big_array= [[2, 5, 7], [3, 1, 4], [6, 8, 9]]; 

Я пытался добавлять массивы через push и якобы эмулировать массивы.

big_array.push("["+var1+","+var2+","+var3+"]"); //это пример добавления первого массива с данными (2,5,7) Но результат получается вот такой, с кавычками: ["[2,5,7]"] //это big_array 

Когда должен быть:
Как это можно сделать?
Отслеживать
317 2 2 серебряных знака 26 26 бронзовых знаков
задан 8 апр 2012 в 12:14
Denis Masster Denis Masster
1,157 5 5 золотых знаков 23 23 серебряных знака 54 54 бронзовых знака
big_array.push(var1, var2, var3);
8 апр 2012 в 12:27
@alexlz — вы добавляете 3 элемента, ТСу нужно добавить массив с тремя элементами
8 апр 2012 в 12:29

3 ответа 3

Сортировка: Сброс на вариант по умолчанию

big_array.push("["+var1+","+var2+","+var3+"]"); // LOL big_array.push([var1, var2 ,var3]);// не. 

Вы запихиваете строку и удивляетесь тому, что в массив добавляется именно строка? О_О

Отслеживать
ответ дан 8 апр 2012 в 12:17
user3545 user3545

А почему я получаю немного не то, что хочется? > big_array [ [ [ 2, 5, 7 ], [ 3, 1, 4 ], [ 6, 8, 9 ] ] ]

8 апр 2012 в 12:31
а.. строка.. точно) спасибо )
8 апр 2012 в 12:34

Значит вы что-то делаете не так, тут без вариантов. К тому-же я понятия не имею что именно вы хотите получить. PS: рискну предположить что вы тупо вызываете push не для того массива Если вы так и не разобрались — предоставьте код

8 апр 2012 в 12:34
Да нет, просто я var’ам присвоил одномерные массивы. Что и видно по результату.
8 апр 2012 в 12:41

ПРИМЕР СОЗДАНИЯ МАССИВА С ИСПОЛЬЗОВАНИЕМ КОНСТРУКТОРА ОБЪЕКТА Array:

var arr = new Array(3);//Создание массива на 3 элемента arr[0] = new Array(3); //вставл. в первый элемент массив на 3 элемента arr[1] = new Array(3); //вставл. в второй элемент массив на 3 элемента arr[2] = new Array(3); //вставл. в третий элемент массив на 3 элемента //. 

ПРИМЕР СОЗДАНИЯ МАССИВА С ИСПОЛЬЗОВАНИЕМ КВАДРАТНЫХ СКОБОК:

var arr = []; //Создание пустого массива arr[0] = []; //вставл. в первый элемент массив arr[1] = []; //вставл. в второй элемент массив arr[2] = []; //вставл. в третий элемент массив //. 

ПРИМЕЧАНИЕ: В JavaScript объекты Array являются динамическим, т.е. количество элементов может быть добавлено или сокращенно в любой момент времени выполнения программы. Исходя из этого вы можете добавить нужное количество элементов нужного типа в любой уровень многомерного массива, как в первом так и втором способе.

ПРИМЕР СОЗДАНИЯ МНОГОМЕРНОГО МАССИВА (10×10) С ИСПОЛЬЗОВАНИЕМ ЦИКЛА:

 var tаblе = new Array (10); // 10 строк таблицы for (var i=0; i < tаblе.length; i++) < tаblе[i] = new Array(10); // 10 столбцов >

Заполнение многомерных массивов JavaScript

Пусть теперь мы хотим в цикле создать какой-нибудь многомерный массив с числами. Например, вот такой двухмерный массив:

[[1, 2, 3], [1, 2, 3], [1, 2, 3]]

Решим поставленную задачу, применив два вложенных цикла. Внешний цикл будет создавать подмассивы, а внутренний — заполнять эти подмассивы числами:

let arr = []; for (let i = 0; i < 3; i++) < arr[i] = []; // создаем подмассив for (let j = 0; j < 3; j++) < arr[i].push(j + 1); // заполняем подмассив числами >> console.log(arr);

Сформируйте с помощью двух вложенных циклов следующий массив:

[[1, 2, 3, 4, 5], [1, 2, 3, 4, 5], [1, 2, 3, 4, 5]]

Сформируйте с помощью двух вложенных циклов следующий массив:

[ [‘x’, ‘x’, ‘x’, ‘x’], [‘x’, ‘x’, ‘x’, ‘x’], [‘x’, ‘x’, ‘x’, ‘x’] ]

Сформируйте с помощью трех вложенных циклов следующий массив:

[ [ [1, 2, 3, 4, 5], [1, 2, 3, 4, 5], ], [ [1, 2, 3, 4, 5], [1, 2, 3, 4, 5], ], [ [1, 2, 3, 4, 5], [1, 2, 3, 4, 5], ], ]

Многомерные массивы в JavaScript

Элементы массива могут быть не только строками и числами, но и массивами. В этом случае у нас получится массив массивов или .

В следующем примере массив arr состоит из трех элементов, в свою очередь являющихся массивами:

let arr = [[‘a’, ‘b’, ‘c’], [‘d’, ‘e’, ‘f’], [‘g’, ‘h’, ‘i’]];

Перепишем в более понятном виде:

let arr = [ [‘a’, ‘b’, ‘c’], [‘d’, ‘e’, ‘f’], [‘g’, ‘h’, ‘i’], ];

В зависимости от уровня вложенности массивы могут быть двухмерными — массив массивов, трехмерными — массив массивов массивов (ну и так далее — четырехмерными, пятимерными и тп).

Приведенный выше массив является двухмерным, так как внутри одного массива расположены другие подмассивы и уже в этих подмассивах нет других массивов.

Чтобы вывести какой-либо элемент из двухмерного массива следует писать уже не одну пару квадратных скобок, а две:

let arr = [ [‘a’, ‘b’, ‘c’], [‘d’, ‘e’, ‘f’], [‘g’, ‘h’, ‘i’], ]; console.log(arr[0][1]); // выведет ‘b’ console.log(arr[1][2]); // выведет ‘f’

Дан следующий массив:

let arr = [ [‘a’, ‘b’, ‘c’], [‘d’, ‘e’, ‘f’], [‘g’, ‘h’, ‘i’], [‘j’, ‘k’, ‘l’], ];

Выведите с его помощью элементы с текстом ‘l’ , ‘e’ , ‘g’ и ‘a’ .

Дан следующий массив:

let arr = [[1, 2], [3, 4], [5, 6]];

Обращаясь к каждому элементу массива найдите сумму всех его элементов.

#7 — Массивы данных. Одномерные и многомерные массивы

#7 - Массивы данных. Одномерные и многомерные массивы

За урок мы научимся работать с массивами данных в языке JavaScript. При помощи массивов можно хранить большие объемы информации в одном единственном месте. Мы изучим одномерные и многомерные массивы данных.

Видеоурок

Массивы позволяют хранить большой объем информации в одном месте. В языке JavaScript можно найти несколько основных типов массивов.

Одномерный массив

Одномерный массив состоит из нескольких элементов, объединенных под одним именем. Чтобы создать массив необходимо создать переменную и присвоить ей значение new Array() . Внутри вы можете через запятую записывать различные значения, которые и будут элементами массива.

В массивах отсчет начинается с 0, поэтому первый элемент по индексу будет равен 0, второй — 1 и так далее.

Примеры создания массива:

var some = new Array(); // Создание пустого массива some[0] = '1'; // Добавление 1 элемента some[1] = 2; // Добавление 2 элемента console.log(some[0]); // Вывод первого элемента var array = new Array(1, 5, 2); // Создание массива со значениями сразу же

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

Для массивов существует несколько дополнительных функций, которые ещё будут изучены в ходе курса. Сейчас был изучен лишь метод length , который позволяет получить длину всего массива.

var elements = new Array(23, 6, 0, true, "Первый"); // Выведет значение 5, так как в массиве 5 элементов console.log(elements.length);

Сперва массивы могут показаться бесполезными, но на самом деле это не так. В дальнейшем вы сможете понять всю важность массивов.

Многомерные массивы

Многомерный массив — это массив, в котором каждый элемент является другим массивом. На практике очень редко используются массивы с более чем третим уровнем вложенности. То есть массивы, в которых все элементы являются другими массивами и в котором все элементы также другие массивы встречаются очень и очень редко на практике.

Мы не будем изучать подобные массивы, так как принцип их построения точно такой же как при работе с двумерными массивами.

Для создания двумерных массивов необходимо использовать двойные квадратные скобки после типа данных. Выглядит такой массив как матрица, а записывается следующим образом:

var x = new Array(new Array(0, 34, 2), new Array(3, 4, 5)); console.log(x[0][1]); // Выведет 34 // Можно их сразу не присваивать var symbols = new Array(new Array(), new Array()); symbols [0][1] = 'A';

Мы видим, что элементы первого массива являются другими массивами. Чтобы выбрать какой-либо объект используйте ту же структуру что и для одномерных массивов, вот только теперь указывайте индекс как первого массива, так и второго:

x[0][1] = 1; // Вместо 34 теперь будет 1
Весь код будет доступен после подписки на проект!

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *