4
A
回答
3
我將:
步驟1:合併兩個表到雙{{2,},{3,B},{1 ,c}}
第2步:對配對進行排序。
第3步:取消合併結果數組。
table1 = {2,3,1}
table2 = {"a","b","c"}
-- Comparison function
function compare(x, y)
return x[1] < y[1]
end
-- Step 1: Merge in pairs
for i,v in ipairs(table1) do
table1[i] = {table1[i], table2[i]}
end
-- Step 2: Sort
table.sort(table1, compare)
-- Step 3: Unmerge pairs
for i, v in ipairs(table1) do
table1[i] = v[1]
table2[i] = v[2]
end
for i = 1,#table1 do
print(table1[i], table2[i])
end
0
試試這個代碼,其中使用標準的功能table.sort
:
table1 = {2,3,1}
table2 = {"a","b","c"}
table3 = {}
for i,v in ipairs(table1) do
table3[table2[i]]=v
end
table.sort(table1, function (a,b)
return table2[a] <= table2[b]
end)
table.sort(table2, function (a,b)
return table3[a] <= table3[b]
end)
print("table1")
for i,v in ipairs(table1) do
print(i,v)
end
print("table2")
for i,v in ipairs(table2) do
print(i,v)
end
5
該函數不修改任何一個表中,並返回根據第一排序的第二個表。您可以在第一個表中傳遞鍵的比較,如table.sort
。
local sort_relative = function(ref, t, cmp)
local n = #ref
assert(#t == n)
local r = {}
for i=1,n do r[i] = i end
if not cmp then cmp = function(a, b) return a < b end end
table.sort(r, function(a, b) return cmp(ref[a], ref[b]) end)
for i=1,n do r[i] = t[r[i]] end
return r
end
例如:
local table1 = {2, 3, 1}
local table2 = {"a","b","c"}
local sorted = sort_relative(table1, table2)
print(table.unpack(sorted))
結果:
c a b
+0
這確實是一種優雅和乾淨的方法。正如諺語所說的那樣,「有一種方法可以讓貓變皮」。 – Tarik 2015-02-11 10:32:47
1
我用鍵值對,並定期排序功能做的工作:
table1 = {2,3,1}
table2 = {"a","b","c"}
table3 = {}
for i, v in ipairs(table2) do
table3[table1[i]] = v
end
table.sort(table1)
table2 = {}
for i = 1,#table1 do
table2[i]=table3[table1[i]]
end
table3=nil
for i = 1,#table1 do
print(table1[i], table2[i])
end
相關問題
- 1. MySQL Select Statement - 兩個表格,按其他表格排序一個表格
- 2. 如何同時插入兩個表格
- 3. 在sqlalchemy中外連接兩個表時按順序排序
- 4. 如何根據另一個有序表格對錶格進行排序?
- 5. 如何通過不同表格中的兩個相同屬性進行排序?
- 6. 按另一個列表的順序對一個列表排序
- 7. 並行排序兩個不同的列表使用jQuery排序
- 8. 使用Javascript排序表格
- 9. 使用CSV排序表格
- 10. 如何排列兩個表格而不使其內容重疊?
- 11. Google表格腳本:在電子表格中按字母順序排序表
- 12. 表格格式,列順序
- 13. 表格排序
- 14. 如何用兩個表格中的唯一行創建表格
- 15. 當兩個網格在同一頁面上時排序
- 16. 如何記住jQuery表格排序中的先前排序順序
- 17. 如何在一個Excel表格中創建兩個表格使用Visual Studio ETL?
- 18. 使用Javascript按數字和字母順序排序表格
- 19. 使包含表格的一個div分爲兩個div,其中包含表格
- 20. 如何堅持jfx表格列的排序順序
- 21. MySQL:如何順序查詢兩個表?
- 22. 使用jquery tablesorter對兩個表集合中的表格數據進行排序
- 23. 使用Scala中的其中一個的排序對三個列表排序
- 24. 自動對錶格中的多個表格進行排序
- 25. 用兩個鍵排序Python列表,但只有一個按相反順序
- 26. 如何排序一個數組列表並設置另一個列表中的java相同的順序
- 27. 如何在兩個列表視圖中同步列順序?
- 28. 如何在一個表格行中使用兩個ng-repeat?
- 29. Python:排序列表使用另一個列表順序,具有不同的長度,沒有'排序'
- 30. SQL:順序由不同的表格
有趣的方法但成本太高。 – Tarik 2015-02-11 07:30:08