网站首页 > 技术文章 正文
最近给京东2022秋招做了一道算法题。 问题需要输出的数据格式是二维数组。 但是我的回答在ac时有问题,二维数组的每个子数组中的值都是一样的。 当时一直卡在寻找二层for循环的bug,但是忽略了问题出在我定义二维数组的方式上,所以这里想讲一下如何定义一个真正的二- 维数组。
我们先看一个例子,网上最常用的定义二维数组的方法
const n = 3
let arr = new Array(n). fill( new Array(n). fill( 0));
console. log(arr)
copy code
看起来是对的,数组里面嵌套了三个数组,和我们想象的二维数组一样,但是问题就在这里。
看起来对吗? 我们来做一个操作给二维数组中的元素赋值
arr[ 0][ 1] = 1;
console. log( "after assignment", arr);
copy code
我勒个去!什么情况下我只给二维数组的第0行第1列赋值1。为什么每个的第一列都变成1?
相信很多人第一次遇到这种情况时,都会有和我一样的疑惑。问题出在哪里?
问题在于 Array.fill()
不熟悉的朋友可以看看MDN上的简单解释
Array.prototype.fill()
我希望你会注意到这句话:“当一个对象被传递给 fill 方法时,数组被填充了对该对象的引用。 "
注意:如果填充的内容是'object'类型,那么对象分配了相同的内存地址,而不是深拷贝对象。
这就解释了上面的问题。我们根据它的内存地址找到了对象并修改了对象本身。这样,其他子数组也发生了变化,因为这些子数组都取自同一个内存地址。因此,上述方法定义的二维数组不能称为真正的二维数组(我这里说的对象其实就是js中的引用类型数据,array、object、map、Set,这些都是。 )
如何定义一个真正的二维数组?
其实很简单,两个for循环就可以完成
let arr1 = new Array(n);
for ( let i = 0; i < n; i++) {
for ( let j = 0; j < n; j++) {
arr1[i] = new Array(n). fill( 0);
}
}
copy code
让我们给它赋值,看看之前和之后的结果
console. log( "before assignment", arr1);
arr1[ 0][ 1] = 1;
console. log( "after assignment", arr1);
copy code
没错,我们定义了一个真正的二维数组
希望大家以后在遇到二维数组问题的时候放弃第一种写法。 我们需要的是一个真正的二维数组。
关注七爪网,获取更多APP/小程序/网站源码资源!
猜你喜欢
- 2024-11-10 趣谈JS二进制:File、Blob、FileReader、ArrayBuffer、Base64
- 2024-11-10 当裸辞遇到了面试难,你需要了解一下这些面试题
- 2024-11-10 JavaScript -- Map vs ForEach javascript map vs foreach
- 2024-11-10 面试官:请说下Object和Map的区别,Map的时间复杂度是多少
- 2024-11-10 从小白到专家:JavaScript 延展操作符的几个基本用法
- 2024-11-10 JavaScript slice()方法用法简介 js中slice函数
- 2024-11-10 《你不知道的 Blob》番外篇 你不知道 小说
- 2024-11-10 js中检测数据类型的方法汇总 检测js对象是数组类型
- 2024-11-10 JS函数式编程工具:数组reduce方法的运用
- 2024-11-10 「前端知乎系列」ArrayBuffer 和 Blob 对象
- 标签列表
-
- content-disposition (47)
- nth-child (56)
- math.pow (44)
- 原型和原型链 (63)
- canvas mdn (36)
- css @media (49)
- promise mdn (39)
- readasdataurl (52)
- if-modified-since (49)
- css ::after (50)
- border-image-slice (40)
- flex mdn (37)
- .join (41)
- function.apply (60)
- input type number (64)
- weakmap (62)
- js arguments (45)
- js delete方法 (61)
- blob type (44)
- math.max.apply (51)
- js (44)
- firefox 3 (47)
- cssbox-sizing (52)
- js删除 (49)
- js for continue (56)
- 最新留言
-