数组去重复
2016-02-24 23:42
246 查看
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.手动去重
用眼看着,一个一个挑选出来,重新输入计算机(开个玩笑)
相关文章推荐
- R语言的饼图(pie)学习
- (转)Linux的chattr与lsattr命令详解
- 地道的表达(二)
- 影响速度优化和ANR日志分析
- 屏幕适配
- 2016寒假读书笔记2-----20135204
- 设计模式:Builder模式(多个构造器参数时可显著改善可读性)
- Codeforces544C:Writing Code
- dialog子线程操作UI异常:Only the original thread that created a view hierarchy can touch its views
- dialog子线程操作UI异常:Only the original thread that created a view hierarchy can touch its views
- C++笔试题 String类的实现 三大复制控制函数
- Integer和int的区别
- java学习日记——Inner Class(内部类)
- 2016/2/24 css画三角形 border的上右下左的调整 以及内区域的无限变小 边界透明
- 用法总结:NSArray,NSSet,NSDictionary-备用
- 51nod 1444 破坏道路
- linux学习笔记三_umask
- 设计模式学习笔记——简单工厂模式
- 非静态内部类为什么可以访问外部类的静态成员
- 《Unity_API解析》 第二章(下) Camera类实例方法