首页投稿(暂停使用,暂停投稿)iOS Developer程序员

Swift 中超快捷去重方法(附集合Set的一点干货)

2016-06-22  本文已影响2075人  高浩浩浩浩浩浩

先上图:


注意:这个去重方法不能保证去重后的顺序和原数组一致!
没看懂?没关系,下面来干货~
这个代码的关键在于用到了集合Set的一种属性:存储相同类型的不同的值

集合类型

Swift语言提供经典的数组字典 两种集合类型来存储集合数据.数组和字典中存储的数据值类型必须明确.这意味着我们不能把不正确的数据类型插入其中.
Swift对显式类型集合的使用确保了我们的代码对工作所需要的类型非常清楚.也让我们在开发中可以早早的找到任何的类型不匹配错误.如果你用变量(var)创建的集合,这些集合就是可变的(增删改).如果用常量(let)创建的,这些集合是不能被操作的.
注意: 如果集合的元素是不变的,那就将集合声明为常量.这样Swift编译器能对你创建的集合做性能优化.

一个set不能单独的从数组字面量推断类型.所以set必须被明确的定义.然而根据swift的类型推断,当你用数组字面量初始化set的时候,如果包含的所以value是一种类型,你可以不写类型.

    var someSet: Set = ["L","o","v","e"]  //判断一个set是否包含一个值
    var isContainAValue = someSet.contains("o")
    print("/(isContainAValue)")  //遍历一个set
    for item in someSet {
        print("/(item)")
    }// 因为set类型没有顺序.所以要按照一个指定的顺序遍历set要使用全局sorted函数.
    for item in someSet.sort() {
        print("/(item)")
    }
    // set的一些基本操作
    let oddDigits:Set = [1,3,5,7,9]
    let evenDigits:Set = [0,2,4,6,8]
    let sigleDigitPrimeNumber:Set = [2,3,5,7]
    
    // 并集
    let unionResult = oddDigits.union(evenDigits).sort()
    print("\(unionResult)")
    //[0,1,2,3,4,5,6,7,8,9]
    
    // 交集
    let intersectResult = oddDigits.intersect(evenDigits).sort()
    print("\(intersectResult)")
    // []
    
    // 前一个包含,后一个不包含的元素
    let subtractResult = oddDigits.subtract(sigleDigitPrimeNumber).sort()
    print("\(subtractResult)")
    // [1, 9]
    
    // 在前一个或者后一个set里面,但是去掉同时包含的元素
    let exclusiveOrResult = oddDigits.exclusiveOr(sigleDigitPrimeNumber).sort()
    print("\(exclusiveOrResult)")
    // [1, 2, 9]
上一篇 下一篇

猜你喜欢

热点阅读