給一個數組arr=[1,2,3,4,5],索引第二位插入'z',設計一個函式change,呼叫change(arr, 2, 'z')返回一個新陣列[1,2,'z',3,4,5]
我想了兩種辦法:
第一種辦法:先插入要新增的元素,再在將原陣列後面的值新增在新陣列上(注意:複製新陣列不能淺拷貝,淺拷貝只是複製記憶體地址,修改新陣列的話原陣列也會改變)
let arr = [1, 2, 3, 4, 5]
// let newarr = arr 淺拷貝(×)
let newarr = JSON.parse(JSON.stringify(arr))
// let newarr = []
// for (let i = 0; i < arr.length; i++) {
// newarr[i] = arr[i]
// }
let change = (arr, index, text) => {
newarr[index] = text
for (let i = index; i < arr.length; i++) {
newarr[i + 1] = arr[i]
}
return newarr
}
console.log(change(arr, 2, 'z'));
第二種辦法:直接迴圈原陣列,判斷傳入要替換的索引值,如果這個i小於這個索引值,直接複製到新陣列,等於這個值直接將新增的元素新增,大於這個值的時候新陣列賦值的時候索引值加一(因為剛才不是加了一個元素嘛)
let arr = [1, 2, 3, 4, 5]
let newChange = (arr, index, text) => {
let narr = []
for (let i = 0; i < arr.length; i++) {
if (i < index) {
narr[i] = arr[i]
}
else if (i == index) {
narr[i] = text
}
else if (i > index) {
newarr[i + 1] = arr[i]
}
}
return newarr
}
console.log(newChange(arr, 2, 'z'));