标签:
在工作工程中我们不必要会遇到,在数组中有重复数据的时候,如何去除重复的数据呢?
第一种:利用NSDictionary的AllKeys(AllValues)方法
代码:
- NSArray *dataArray = @[@"2014-04-01",@"2014-04-02",@"2014-04-03",
- @"2014-04-01",@"2014-04-02",@"2014-04-03",
- @"2014-04-01",@"2014-04-03",@"2014-04-03",
- @"2014-04-01",@"2014-04-02",@"2014-04-03",
- @"2014-04-01",@"2014-04-02",@"2014-04-03",
- @"2014-04-01",@"2014-04-02",@"2014-04-03",
- @"2014-04-04",@"2014-04-06",@"2014-04-08",
- @"2014-04-05",@"2014-04-07",@"2014-04-09",];
- NSMutableDictionary *dic = [[NSMutableDictionary alloc]initWithCapacity:0];
- for(NSString *str in dataArray)
- {
- [dic setValue:str forKey:str];
- }
- NSLog(@"%@",[dic allKeys]);
打印结果:
(
"2014-04-09",
"2014-04-02",
"2014-04-08",
"2014-04-01",
"2014-04-07",
"2014-04-06",
"2014-04-05",
"2014-04-04",
"2014-04-03"
)
第二种方法:利用NSSet的AllObjects方法
实例代码:
- NSArray *dataArray = @[@"2014-04-01",@"2014-04-02",@"2014-04-03",
- @"2014-04-01",@"2014-04-02",@"2014-04-03",
- @"2014-04-01",@"2014-04-03",@"2014-04-03",
- @"2014-04-01",@"2014-04-02",@"2014-04-03",
- @"2014-04-01",@"2014-04-02",@"2014-04-03",
- @"2014-04-01",@"2014-04-02",@"2014-04-03",
- @"2014-04-04",@"2014-04-06",@"2014-04-08",
- @"2014-04-05",@"2014-04-07",@"2014-04-09",];
- NSSet *set = [NSSet setWithArray:dataArray];
- NSLog(@"%@",[set allObjects]);
打印结果:
(
"2014-04-01",
"2014-04-02",
"2014-04-03",
"2014-04-04",
"2014-04-06",
"2014-04-08",
"2014-04-05",
"2014-04-07",
"2014-04-09"
)
第三种方法,利用数组的containsObject来去除
代码如下:
- NSArray *dataArray = @[@"2014-04-01",@"2014-04-02",@"2014-04-03",
- @"2014-04-01",@"2014-04-02",@"2014-04-03",
- @"2014-04-01",@"2014-04-03",@"2014-04-03",
- @"2014-04-01",@"2014-04-02",@"2014-04-03",
- @"2014-04-01",@"2014-04-02",@"2014-04-03",
- @"2014-04-01",@"2014-04-02",@"2014-04-03",
- @"2014-04-04",@"2014-04-06",@"2014-04-08",
- @"2014-04-05",@"2014-04-07",@"2014-04-09",];
- NSMutableArray *listAry = [[NSMutableArray alloc]init];
- for (NSString *str in dataArray) {
- if (![listAry containsObject:str]) {
- [listAry addObject:str];
- }
- }
- NSLog(@"%@",listAry);
打印结果:
(
"2014-04-01",
"2014-04-02",
"2014-04-03",
"2014-04-04",
"2014-04-06",
"2014-04-08",
"2014-04-05",
"2014-04-07",
"2014-04-09"
)
第四种方法:利用keyValue的方式(自己不是太明白)
打印结果如下:
(
"2014-04-01",
"2014-04-02",
"2014-04-03",
"2014-04-04",
"2014-04-06",
"2014-04-08",
"2014-04-05",
"2014-04-07",
"2014-04-09"
)
总结:这几种方式都可以实现去除重复的数据,当然也可以用for循环的方式去除方法不再叙述;淡然也参考了别人的东西进行的总结
案例的使用:
服务器返回一个带有日期的数组,当然有重复的日期,同一个的日期的列表要在同一个地方的话,头部显示日期的话,可以使用到此方法去除重复的,当然,根据具体的情况代码和逻辑是不同的!
去除重复的数据
标签:
原文地址:http://www.cnblogs.com/MyBlogZH/p/5586505.html