요소가 없는 배열을 선언해보겠습니다.
let cities = [];
cities
라는 변수에 빈 배열을 할당해주었습니다. 그리고 아래와 같이 요소를 하나씩 추가할 수 있습니다.
cities[0] = "서울"; // ["서울"]
cities[1] = "대전"; // ["서울", "대전"]
cities[2] = "대구"; // ["서울", "대전", "대구"]
그리고 6번째 요소에 미리 "제주도"를 할당해 볼까요?
cities[5] = "제주도";
왠지 차례대로 요소를 추가해야할 것 같지만, 이렇게 원하는 위치에 마음대로 요소를 할당할 수 있습니다.
cities
의 4, 5번째 요소를 console.log
로 출력하면 뭐라고 나오나요?
직접 작성해서 출력되는 값을 확인해보세요.
확인하셨나요?
아무것도 할당하지 않았기에 undefined
라고 출력됩니다.
이로써 다음과 같이 총 6개의 요소가 있는 배열이 되었습니다.
["서울", "대전", "대구", undefined, undefined, "제주도"]
요소를 수정하고 싶을 때는 아래와 같이 배열의 인덱스에 접근하여 값을 할당하면 됩니다.
cities[5] = "포항";
console.log(cities[5]);
다른 방법으로도 요소를 추가 할 수 있습니다.
let cities = [];
cities.push("경주", "전주");
cities.unshift("인천");
push()
, unshift()
메소드는 배열에 요소를 추가해주는 함수입니다.
둘의 차이는 요소들이 배열에 추가되는 위치가 다르다는 것 입니다.
push
는 배열의 마지막 부분, 즉 꼬리에 요소들을 추가하고,
unshift
는 배열의 맨 앞부분, 즉 머리 부분에 요소를 추가합니다.
console.log
로 cities
배열이 어떻게 나오는지 확인하고 넘어가주세요.
console.log(cities);
확인 하셨나요?
그런데 생각해보면, cities
라는 변수는 방금 만든 변수인데 push
라는 메소드를 사용할 수 있게 되었네요?
결론부터 이야기 하자면, cities
라는 변수에 []
배열을 할당하는 순간, cities
라는 변수는 Array형이 되었습니다.
Array형에는 기본적으로 제공되는 내장 메소드들이 많이 있습니다. 그 중에 방금 살펴본 push
, unshift
가 있는 것입니다.
정리하자면, 배열 조작 방법에는 2가지가 있습니다.
push
, unshift
메소드로 추가let day = ['m', 's', 'w', 't'];
day[1] = 't';
day[4] = 'f';
day[5] = 's'; // 방법 (1)
let month = [1, 2, 3, 4]
month.push(5); // 방법 (2)
배열에 요소를 추가하는 것 말고도, 요소를 제거 할 수도 있습니다.
cities.pop();
console.log(cities)
pop
메소드를 사용하면 마지막 요소가 제거되고, 마지막 요소의 값을 반환합니다.
let lastCity = cities.pop();
console.log(lastCity);
divideArrayInHalf
함수는 array를 인자로 받습니다. 이 array는 숫자 값으로 만 구성되어 있으며 총 5개의 요소(element)들로 구성되어 있습니다.
divideArrayInHalf
함수는 인자로 들어온 array 로 부터 새롭게 구성된 배열 result 을 리턴합니다.
array 요소들 중 10과 같거나 작은 값의 요소들은 result의 맨 앞으로, 10보다 큰 값의 요소들은 result의 맨 뒤로 재구성된 배열을 리턴 해주세요.
재구성이 되는 순서는 array의 맨 뒤 요소부터 맨 앞 요소까지 입니다. 즉, 배열의 뒷 요소 부터 재구성을 진행해주세요.
예를 들어, 인자로 들어오는 array가 다음과 같을 때,
[1, 20, 10, 5, 100]
result 배열이 만들어 지는 순서는 다음과 같습니다.
따라서 아래와 같은 result가 리턴 되어야 합니다.
[1, 10, 5, 100, 20]
// Assignment - 다음 함수 안에 코드를 구현하세요
function divideArrayInHalf(array) {
let result = [];//빈 배열 생성
for(let i = array.length; i >= 0; i--){ //역순으로 loop
if(array[i] <= 10){//10보다 같거나작으면 unshift로 재배열
result.unshift(array[i]);
}else if(array[i] > 10){//10보다 크면 push 로 재배열
result.push(array[i]);
}
}
return result; //return 으로 출력
}
// 아래의 코드는 절대로 수정하거나 삭제하지 마세요.
module.exports = {divideArrayInHalf};