【发布时间】:2017-10-18 12:56:25
【问题描述】:
问题
我有一个二维数组,它实际上是输入到 Google 表格中的数据。它按逻辑排序,由用户定义。
目标是在该表的末尾输入新行,然后按位置排序。
说“按位置”是指“欧洲”排在“美国”之前,因为用户之前输入过。
这是用于测试的示例数组:
var data =
[
['Earth', 'Europe', 'Britain', 'London'],
['Earth', 'Europe', 'Britain', 'Manchester'],
['Earth', 'Europe', 'Britain', 'Liverpool'],
['Earth', 'Europe', 'France', 'Paris'],
['Earth', 'Europe', 'France', 'Lion'],
['Earth', 'Europe', 'Italy', 'Rome'],
['Earth', 'Europe', 'Italy', 'Milan'],
['Earth', 'Europe', 'Greece', 'Athenes'],
['Earth', 'Asia', 'China', 'Pekin'],
['Earth', 'Africa', 'Algeria', 'Algiers'],
['Earth', 'America', 'USA', 'Dallas'],
['Earth', 'America', 'USA', 'New York'],
['Earth', 'America', 'USA', 'Chicago'],
['Tatooine', 'Yulab', 'Putesh', 'ASU'],
['Tatooine', 'Yulab', 'Putesh', 'Niatirb'],
['Tatooine', 'Yulab', 'Zalip', 'Duantan'],
['Tatooine', 'Asia', 'Solo', 'Lion'],
['Tatooine', 'Asia', 'Solo', 'To'],
['Earth', 'America', 'USA', 'San Francisco'],
['Tatooine', 'Yulab', 'Koko', 'Traiwau'],
['Venus', 'Yoo', 'Van', 'Derzar'],
['Tatooine', 'Chendoo', 'org', 'Eccel']
];
正确的结果数组是:
/*
[ [Earth, Europe, Britain, London],
[Earth, Europe, Britain, Manchester],
[Earth, Europe, Britain, Liverpool],
[Earth, Europe, France, Paris],
[Earth, Europe, France, Lion],
[Earth, Europe, Italy, Rome],
[Earth, Europe, Italy, Milan],
[Earth, Europe, Greece, Athenes],
[Earth, Asia, China, Pekin],
[Earth, Africa, Algeria, Algiers],
[Earth, America, USA, Dallas],
[Earth, America, USA, New York],
[Earth, America, USA, Chicago],
[Earth, America, USA, San Francisco],
[Tatooine, Yulab, Putesh, ASU],
[Tatooine, Yulab, Putesh, Niatirb],
[Tatooine, Yulab, Zalip, Duantan],
[Tatooine, Yulab, Koko, Traiwau],
[Tatooine, Asia, Solo, Lion],
[Tatooine, Asia, Solo, To],
[Tatooine, Chendoo, org, Eccel],
[Venus, Yoo, Van, Derzar]
]
*/
我想为此使用脚本。
我的解决方案
我制作了自己的脚本版本,请看这里:
https://github.com/Max-Makhrov/positional-sorting/blob/master/main.js
算法的工作原理
该算法从第一行开始查找组:地球 > 欧洲 > 英国。然后它会尝试在以后的条目中找到该组的匹配项。
我还考虑为较早的条目分配更高的索引。
问题
问题:有没有更好的方法:
- 完成相同任务的代码更少
- 按位置对数组进行排序的更通用方法
- 需要足够快的解决方案,因为我将使用工作表中的代码,它有limits on script time。
【问题讨论】:
-
@Luca,我已经编辑了问题并将其限制为确定适当的答案。能否请您重新打开它。我得到了正确答案,希望我的问题对其他用户有所帮助
标签: javascript sorting google-apps-script google-sheets grouping