当前位置:网站首页>Swift--多条件排序
Swift--多条件排序
2022-08-09 18:19:00 【锐意无限】
关于排序我们都知道swift有专门提供的函数sort给我们使用,但是sort这个函数只能对单条件进行排序,那如果我们遇到多条件和多属性的时候怎么进行排序呢?我们进行就研究下
首先我们创建一个Person结构来进行测试验证
person包含名、姓、和生日,我们下面会对这三个属性进行联合排序
struct Person {
let first: String // 姓
let last: String // 名
let yearOfBirth: Int // 生日
init(first: String, last: String, yearOfBirth: Int) {
self.first = first
self.last = last
self.yearOfBirth = yearOfBirth
// super.init() 在这里被隐式调用
}
}
我们先创建一个数组:
let people = [
Person(first: "Emily", last: "Young", yearOfBirth: 2002),
Person(first: "David", last: "Gray", yearOfBirth: 1991),
Person(first: "Robert", last: "Barnes", yearOfBirth: 1985),
Person(first: "Ava", last: "Barnes", yearOfBirth: 2000),
Person(first: "Joanne", last: "Miller", yearOfBirth: 1994),
Person(first: "Ava", last: "Barnes", yearOfBirth: 1998)
]
然后我们对这个数组进行排序,规则是先按照姓排序,再按照名排序,最后是出生年份
这样我们就是三个条件联合排序了
首先我们要理清这个排序的逻辑:
多条件排序的判断方式是:先比较第一个条件的排序,只有当第一个条件相等时候,才转到下一个条件去判断,直到找到一个不相等的条件
下面我们根据这个逻辑开始谢代码:
let newPeople = people.sorted {
lhs, rhs in
// 我们先判断第一个条件
if lhs.first == rhs.first {
// 当第一个添加相等的时候才去判断下一个条件,以此类推
if lhs.last == rhs.last {
return lhs.yearOfBirth < rhs.yearOfBirth
}
return lhs.last < rhs.last
}
// 不相等的时候判断排序
return lhs.first < rhs.first
}
print( newPeople)
这时候打印是:
[Algorithm.Person(first: "Ava", last: "Barnes", yearOfBirth: 1998),
Algorithm.Person(first: "Ava", last: "Barnes", yearOfBirth: 2000),
Algorithm.Person(first: "David", last: "Gray", yearOfBirth: 1991),
Algorithm.Person(first: "Emily", last: "Young", yearOfBirth: 2002),
Algorithm.Person(first: "Joanne", last: "Miller", yearOfBirth: 1994),
Algorithm.Person(first: "Robert", last: "Barnes", yearOfBirth: 1985)]
三个条件的排序我们知道了,但是如果是N个条件呢,这时候我们会在里面写很多if else,这明显不符合我们的开发效率,所以我们可以改编下上面的代码,我们把N个条件进行数组话,放在一个数组里面,然后去遍历这个数组中的条件进行判断,看下行不:
// 首先我们定个闭包别名
typealias AreInIncreasingOrder = (Person,Person) -> Bool
let newPeople = people.sorted {
lhs, rhs in
// 条件联合
// 首要的条件放第一个,按规则的循序添加排序条件
let predicates:[AreInIncreasingOrder] = [
{
$0.first < $1.first },
{
$0.last < $1.last },
{
$0.yearOfBirth < $1.yearOfBirth }
]
for predicate in predicates {
if !predicate(lhs, rhs) && !predicate(rhs,lhs) {
continue
}
return predicate(lhs,rhs)
}
return false
}
print(newPeople)
打印结果:
[Algorithm.Person(first: "Ava", last: "Barnes", yearOfBirth: 1998),
Algorithm.Person(first: "Ava", last: "Barnes", yearOfBirth: 2000),
Algorithm.Person(first: "David", last: "Gray", yearOfBirth: 1991),
Algorithm.Person(first: "Emily", last: "Young", yearOfBirth: 2002),
Algorithm.Person(first: "Joanne", last: "Miller", yearOfBirth: 1994),
Algorithm.Person(first: "Robert", last: "Barnes", yearOfBirth: 1985)]
结果跟上面的方法打印的结果一样,完美!
边栏推荐
- C#/VB.NET:从PowerPoint文档中提取文本和图片
- MFC教程
- Start cleaning up the long-term divers in the electronic chart development group again
- Flink运行架构
- Ros简介
- AWS CodePipeLine 跨账号部署ECS
- Ng DevUI 周下载量突破1000啦!
- IDEA快捷代码实时模板
- 网络安全:常见的网络协议
- Paper sharing: "FED BN" uses the LOCAL BATCH NORMALIZATION method to solve the Non-iid problem
猜你喜欢
随机推荐
16 张图解 | 淘宝 10年架构演进
释放数据价值的真正法宝,数据要素市场化开发迫在眉睫
2022深圳(软考高级)信息系统项目管理师认证报名
[免费专栏] Android安全之Android工程模式
OpenHarmony如何查询设备类型
哈希表
Flume (六) --------- Flume 数据流监控
基于设计稿识别的可视化低代码系统实践
MYSQL物理存储文件的页和INNOBUF的页是否有大小区别?
基于CC2530 E18-MS1-PCB Zigbee DIY作品
PHP基础笔记-NO.4
图像处理部分详细目录
AWS CodePipeLine deploys ECS across accounts
数学建模——模拟退火
线性代数学习笔记
数据库注入提权总结(一)
程序健壮性
切绳子【洛谷P1577】【二分】
[免费专栏] Android安全之ZIP文件目录遍历漏洞
基于CC2530 E18-MS1-PCB Zigbee DIY作品(三)
![[免费专栏] Android安全之Android奇淫run-as命令](/img/d5/771802eb57f24c1cf88657f5c5a724.png)
![[免费专栏] Android安全之Android工程模式](/img/9e/373a513dd3cd4681ff969432c9dfd5.png)




![[免费专栏] Android安全之Android Studion 动态调试APK的两种方法](/img/05/10769eadd2fb3e5249975ac93e48ed.png)
![[免费专栏] Android安全之数据存储与数据安全【大集合】](/img/bc/9d71ff1de27156e11cde169022f4a1.png)

