数组去重复

1.开辟新的内存空间

判断是否存在,若不存在则添加到数组中,得到最终结果的顺序不发生变化

    NSArray *originalArr = @[@1, @2, @3, @1, @3]; NSMutableArray *resultArrM = [NSMutableArray array]; for (NSString *item in originalArr) { if (![resultArrM containsObject:item]) { [resultArrM addObject:item]; } } NSLog(@"result : %@", resultArrM); 
2.利用NSDictionary的AllKeys(AllValues)方法

可以将NSArray中的元素存入一个字典,然后利用AllKeys或者AllValues取得字典的所有键或值,这些键或值都是去重的

    NSArray *originalArr = @[@1, @2, @3, @1, @3]; NSMutableDictionary *dictM = [NSMutableDictionary dictionary]; for (NSNumber *n in originalArr) { [dict setObject:n forKey:n]; } NSLog(@"%@",[dictM allValues]); 

注:结果为无序的, 也就是说不包吃原有顺序, 可自行加入排序算法

3.利用NSSet特性, 放入集合自动去重

NSSet的特性: 确定性、无序性、互异性
这种方法更快,利用NSSet不会添加重复元素的特性。不过去重的数组没有进行排序,如果需要排序,可以使用NSSortDescriptor类。

    NSArray *originalArr = @[@1, @2, @3, @1, @3];
    NSSet *set = [NSSet setWithArray:originalArr];
    NSLog(@"result: %@", [set allObjects]);

4.通过valueForKeyPath, 去重只需一行代码

    NSArray *originalArr = @[@1, @2, @3, @1, @3];
    NSArray *result = [originalArr valueForKeyPath:@"@distinctUnionOfObjects.self"];

5.手动去重

用眼看着,一个一个挑选出来,重新输入计算机(开个玩笑)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值