首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >对数组进行快速排序,并返回索引和元素数组

对数组进行快速排序,并返回索引和元素数组
EN

Stack Overflow用户
提问于 2017-06-01 07:06:37
回答 1查看 2.1K关注 0票数 4

我希望对数组进行排序,并返回排序数组中的索引和元素数组;

ie:

代码语言:javascript
复制
var filtered = self.existingOrders.sorted(by: { (eo1:ExistingOrder, eo2:ExistingOrder) -> Bool in
                return (eo1.value < eo2.value)
            }).index(0, offsetBy: 0)

这给了我一个特定数字的索引。

我想要一个元素和索引的排序数组;这样我就可以获取必要的索引并对它们进行操作。

我怎样做才能做到;

代码语言:javascript
复制
// pseduocode:

var filtered:(Index, Element) = self.existingOrders.sortByLowest.return(flatMap(index, element))

或者有可能连一个枚举数来帮助我列出索引的所有项目;后排序?

ie:

代码语言:javascript
复制
 let filtered = self.existingOrders.sorted(by: { (eo1:ExistingOrder, eo2:ExistingOrder) -> Bool in
                return (eo1.value < eo2.value)
            }).enumerated().flatMap({ (offset:Int, element:ExistingOrder) -> (Int, ExistingOrder) in
                return (offset, element)
            })

我希望得到一个排序数组,并将一个索引和元素返回给我的过滤器变量。

我怎样才能做到这一点?

非常感谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-06-01 07:13:24

如果我正确地理解了您的问题,那么您可以使用enumerated()获得一个偏移/元素对序列,并根据元素对其排序。示例:

代码语言:javascript
复制
let array = ["C", "A", "B"]

let sortedElementsAndIndices = array.enumerated().sorted(by: {
    $0.element < $1.element
})

print(sortedElementsAndIndices) // [(1, "A"), (2, "B"), (0, "C")]

每个元组中的第一个元素是原始数组中第二个元组元素的索引。

在你的情况下,你会觉得

代码语言:javascript
复制
let sorted = self.existingOrders.enumerated().sorted(by: {
    $0.element.value < $1.element.value
})
票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44300737

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档