Swift--多条件排序

31 篇文章 5 订阅
本文介绍了如何在 Swift 中进行多条件排序,通过一个Person结构体实例展示了先按姓、再按名、最后按出生年份的联合排序过程。首先,通过嵌套if语句实现三条件排序,然后优化为使用闭包数组动态处理任意数量的排序条件,提高代码的可读性和可扩展性。这种方法适用于需要对多个属性进行排序的情况。
摘要由CSDN通过智能技术生成

关于排序我们都知道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)]

结果跟上面的方法打印的结果一样,完美!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值