从给定的字符串创建数组的矩阵

时间:2019-04-23 22:39:27

标签: javascript

我试图根据给定的字符串('bananabar')创建一个数组矩阵。每个矩阵元素都应该最后取一个字符串元素并预先附加。

例如:第一个数组为['b','a','n','a','n','a','b','a','r']和下一个矩阵数组为['r','b','a','n','a','n','a','b','a']。

这是我的职能:

function createTable(s) {

      var strArr = s.split('');
      var arr = [];

      for (i=0; i<s.length; i++) {
        arr[i] = strArr;
        console.log(arr[i])
        strArr.unshift(strArr.pop()); 
      }
      console.log(arr, 'arr')
      return arr;
    }

当我在控制台上用for循环记录arr [i]时,看看是否从strArr中删除了一个数组元素并将其追加到前面,并且显示正确。以下是for循环中的控制台日志语句。

[ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ]
[ 'r', 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a' ]
[ 'a', 'r', 'b', 'a', 'n', 'a', 'n', 'a', 'b' ]
[ 'b', 'a', 'r', 'b', 'a', 'n', 'a', 'n', 'a' ]
[ 'a', 'b', 'a', 'r', 'b', 'a', 'n', 'a', 'n' ]
[ 'n', 'a', 'b', 'a', 'r', 'b', 'a', 'n', 'a' ]
[ 'a', 'n', 'a', 'b', 'a', 'r', 'b', 'a', 'n' ]
[ 'n', 'a', 'n', 'a', 'b', 'a', 'r', 'b', 'a' ]
[ 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r', 'b' ]

但是,当我控制台记录返回的结果时,它会显示以下数组数组:

[ [ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
  [ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
  [ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
  [ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
  [ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
  [ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
  [ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
  [ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ],
  [ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ] ] 

但是我想要通过以下方式输出

   [ [ 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r' ]
    [ 'r', 'b', 'a', 'n', 'a', 'n', 'a', 'b', 'a' ]
    [ 'a', 'r', 'b', 'a', 'n', 'a', 'n', 'a', 'b' ]
    [ 'b', 'a', 'r', 'b', 'a', 'n', 'a', 'n', 'a' ]
    [ 'a', 'b', 'a', 'r', 'b', 'a', 'n', 'a', 'n' ]
    [ 'n', 'a', 'b', 'a', 'r', 'b', 'a', 'n', 'a' ]
    [ 'a', 'n', 'a', 'b', 'a', 'r', 'b', 'a', 'n' ]
    [ 'n', 'a', 'n', 'a', 'b', 'a', 'r', 'b', 'a' ]
    [ 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r', 'b' ] ]

看看您是否能找出导致问题的原因。

2 个答案:

答案 0 :(得分:1)

这是一种方法,可以使用两次Array.from()String.prototype.charAt()

const makeMatrix = s =>
  Array.from({ length: s.length }, (_, i) =>
    Array.from({ length: s.length }, (_, j) =>
      s.charAt((j - i + s.length) % s.length)));

console.log(JSON.stringify(makeMatrix('bananabar')));

答案 1 :(得分:1)

出现此问题的原因是您将对 same 数组的引用推入矩阵,然后一次又一次地更改同一数组。每次pushunshift都会对矩阵的每一行进行处理,因为它们都是对同一数组的引用。

还有许多其他方法可以执行此操作,但是为了说明问题,这是您的原始代码,但有一点点更改。在推入矩阵之前,它使用slice()制作数组的副本:

let strArr = ['b', 'a', 'n', 'a', 'n', 'a', 'b', 'a', 'r']
var arr = strArr.slice();

for (i=0; i<strArr.length; i++) {
    arr[i] = strArr.slice(); // copy the array
    strArr.unshift(strArr.pop()); 
 }
 console.log(arr.map(row => row.join(',')))