• Swift--多条件排序


    关于排序我们都知道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() 在这里被隐式调用
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    我们先创建一个数组:

    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)
        ]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    然后我们对这个数组进行排序,规则是先按照姓排序,再按照名排序,最后是出生年份
    这样我们就是三个条件联合排序了

    首先我们要理清这个排序的逻辑:
    多条件排序的判断方式是:先比较第一个条件的排序,只有当第一个条件相等时候,才转到下一个条件去判断,直到找到一个不相等的条件
    下面我们根据这个逻辑开始谢代码:

    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)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    这时候打印是:

    [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
    • 2
    • 3
    • 4
    • 5
    • 6

    三个条件的排序我们知道了,但是如果是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)
        
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    打印结果:

    [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
    • 2
    • 3
    • 4
    • 5
    • 6

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

  • 相关阅读:
    域内持久化后门
    【单目3D目标检测】SMOKE + MonoFlex 论文解析与代码复现
    用Calendar代替SimpleDateFormat
    nvm报错: ERROR open \settings.txt: The system cannot find the file specified
    基于Zookeeper搭建Kafka高可用集群(实践可用)
    电子警察联网解决方案,让违法无处遁逃
    windows查看后台执行中的python或bat脚本
    docker服务CPU飙高排查
    【分布式系统】分布式缓存Redis集群原理与环境搭建
    Scrum联盟权威认证CSM<ScrumMaster>官方认证课
  • 原文地址:https://blog.csdn.net/qq_30963589/article/details/126038612