如果最长的表的长度大于或等于 5,如何将每个表的长度更改为等于最长的表?

Posted

技术标签:

【中文标题】如果最长的表的长度大于或等于 5,如何将每个表的长度更改为等于最长的表?【英文标题】:How can I change the length of each table to be equal to the longest one provided that the longest one has a length greater than or equal to 5? 【发布时间】:2019-04-13 17:46:00 【问题描述】:

假设我在打字稿中有一个二维数组。在源代码中是这样的:

    tsvData: any;
    this.tsvData = this.UploaderService.tsvData.split("\n").map(function(row)return row.split("\t"););

如果最长的表的长度大于或等于 5,我想将每个表的长度更改为等于最长的表。如果最长表的长度小于 5,我想将每个表的长度更改为 5。我想用空字符串填充缺失的位置。我添加了两个例子来理解我的目标是什么。另外,我想删除所有带有空字符串的数组。

示例 1

在这个例子中,最长的数组等于 4,所以我将每个表的长度更改为 5。

输入:

[["text1", "text2", "text3", "text4"], 
["text5", "text6"], 
["text7"],
["text8", "text9", "text10"],
[""]]

输出:

[["text1", "text2", "text3", "text4", ""], 
["text5", "text6", "", "", ""], 
["text7", "", "", "", ""],
["text8", "text9", "text10", "", ""]]

示例 2

在本例中,最长的数组等于 6,所以我将每个表的长度更改为 6。

输入:

[["text1", "text2", "text3", "text4"], 
["text5", "text6"], 
["text7"],
["text8", "text9", "text10", "text11", "text12", "text13"],
[""]]

输出:

[["text1", "text2", "text3", "text4", "", ""], 
["text5", "text6", "", "", "", ""], 
["text7", "", "", "", "", ""],
["text8", "text9", "text10", "text11", "text12", "text13"]]

【问题讨论】:

【参考方案1】:

让我们把它分解成几个步骤:

    求二维数组的最大长度。 检查是否为>= 5。在此基础上,创建一个maxLength。 然后循环遍历二维数组,创建剩余数组并用"" 填充它。 将剩余数组与二维数组的每一项合并。

试试这个:

var initialTime = performance.now();

var array1 = [
  ["text1", "text2", "text3", "text4"], 
  ["text5", "text6"], 
  ["text7"],
  ["text8", "text9", "text10"],
  [""]
];

var array2 = [
  ["text1", "text2", "text3", "text4"], 
  ["text5", "text6"], 
  ["text7"],
  ["text8", "text9", "text10", "text11", "text12", "text13"],
  [""]
];

function fillRestItems(arrays) 
  var maxArrayLength = Math
    .max(...arrays.map(array => array.length));

  var maxLength = maxArrayLength >= 5 ? maxArrayLength : 5;

  return arrays
  .map(arr => 
    if(!(arr.length === 1 && arr[0] === "")) 
      var addedArray = new Array(maxLength - arr.length).fill("");
      return [...arr, ...addedArray];
    
  )
  .filter(array => array !== undefined);


console.log('Filled Array 1:', fillRestItems(array1));
console.log('Filled Array 2: ', fillRestItems(array2));

var finalTime = performance.now();
console.log(`This took: $(finalTime - initialTime) ms`);

【讨论】:

这几乎是我想要实现的,但是在 [""] 的情况下它返回 ["", "", "", "", ""] 但它应该删除这个数组。 谢谢,您的解决方案和 Sid 的解决方案都能完美运行。当然,我两个都投了,但我只能接受一个。在这种情况下,我必须选择性能更好的解决方案。你觉得哪一个更好? 是的,我更新了问题。感谢您的帮助。 我犯了一个错误。我没有检查表中最长数组短于 5 的情况。不幸的是,Sid 的解决方案不能正常工作。我接受你的解决方案。【参考方案2】:

第一步是找到最大大小的子数组。

let arr = [["text1", "text2", "text3", "text4"], 
            ["text5", "text6"], 
            ["text7"],
            ["text8", "text9", "text10"],
            [""]];

arr = arr.filter(e => e.every(x => x !== ""))    

const maxLength = Math.max(...arr.map(a => a.length));

下一步是用空白值填充数组。

arr.forEach(e => 
    while(e.length < maxLength)
        e.push("");
    
);

console.log(arr);

我相信有更好的方法可以做到这一点,因为算法的时间复杂度是 O(n2)

【讨论】:

这几乎是我想要实现的目标,但是在 [""] 的情况下它返回 ["", "", "", "", ""] 但它应该删除这个数组。 谢谢,您的解决方案和 SiddAjmera 的解决方案都能完美运行。当然,我两个都投了,但我只能接受一个。在这种情况下,我必须选择性能更好的解决方案。你觉得哪个更好? 先回答谁就去。 ;) 我犯了一个错误。当表中最长的数组短于 5 时,我没有检查案例。在您的情况下,它不起作用。两种情况下的性能相似,因此根据您的建议,我接受 SiddAjmera 的解决方案。

以上是关于如果最长的表的长度大于或等于 5,如何将每个表的长度更改为等于最长的表?的主要内容,如果未能解决你的问题,请参考以下文章

线性表的顺序存储结构

HashMapLinkedHashMap

HashMapLinkedHashMap

无论如何分配一个等于id本身的表的默认值?

新增5 最长不含重复字符的子字符串

使用“大于”的数据透视表的报表过滤器