iOS数组的去重,判空,删除元素,删除重复元素 等

一: 去重

有时需要将NSArray中去除重复的元素,而存在NSArray中的元素不一定都是NSString类型。今天想了想,加上朋友的帮助,想到两种解决办法,先分述如下。

1.利用NSDictionary的AllKeys(AllValues)方法

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

示例代码:

NSArray *arr = @[@111,@222,@111];

NSMutableDictionary *dict = [NSMutableDictionary dictionary];

for (NSNumber *number in arr) {

[dict setObject:number forKey:number];

}

NSLog(@"%@",[dict allValues]);

输出结果为:

2013-05-21 12:03:49.449 test1[4377:c07] (

111,

222

)

2.利用NSSet的AllObjects方法

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

示例代码:

NSArray *arr = @[@111,@222,@111];

NSSet *set = [NSSet setWithArray:arr];

NSLog(@"%@",[set allObjects]);

输出结果为:

2013-05-21 12:06:26.508 test1[4547:c07] (

111,

222

)

排序的去重

很多时候可能会遇到需要去除NSArray重复的元素,用了很多方法。

最方便快捷的是NSSet.但是NSSet去重后有时候数组元素的顺序会

打乱。于是换了另外一种方法如下:

NSMutableArray *categoryArray = [[NSMutableArray alloc] init];

for (unsigned i = 0; i < [nameArray count]; i++){

if ([categoryArray containsObject:[nameArray objectAtIndex:i]] == NO){

[categoryArray addObject:[nameArray objectAtIndex:i]];

}

}

顺序就不会乱了。

二  、有些开发者,在判断数组是否为空时,会写成:

[objc] view plain copy

  1. if (array != nil)

或是:

[objc] view plain copy

    1. if (array.count != 0)       三 : 删除元素

      这个问题其实可以分为两种方式来看待:一种是在循环遍历的时候就进行删除操作,另外一种就是在循环遍历完之后在进行操作

      一》在循环遍历的时候就进行操作,有以下几种方法:

      1.在使用快速遍历进行删除操作之后要加break,来结束,这样就不会出现问题。

      NSMutableArray *arr1 = [[NSMutableArrayalloc]initWithObjects:@"ABC",@"DEF",@"ABC",@"ABC",@"QWE",@"TTT",nil];

      for(NSString *strin arr1)

      {

      NSLog(@"%@",str);

      if([str isEqualToString:@"ABC"])

      {

      [arr1 removeObject:str];

      break;

      }

      }

      2.使用索引计数的方式,但是要注意的是当我们删除一个元素时,arr.count 是进行改变的,所以可能造成漏删,所以我们要对索引计数进行操作,每当删除一个元素时,都让i - 1,这样才能达到不重不漏的效果

      NSMutableArray *arr1 = [[NSMutableArrayalloc]initWithObjects:@"ABC",@"DEF",@"ABC",@"ABC",@"QWE",@"TTT",nil];

      for(int i  =0;i<arr1.count;i++)

      {

      NSLog(@"%lu",arr1.count);

      NSString *str = arr1[i];

      if([str isEqualToString:@"ABC"])

      {

      [arr1 removeObjectAtIndex:i];

      i--;

      }

      }

      for(NSString *strin arr1)

      {

      NSLog(@"%@",str);

      }

      3.也是使用引用计数的方式,不过要倒序方式来进行删除,这样,即使后面的元素被删除之后,也不会影响前面的元素在数组中的index

      NSMutableArray *arr1 = [[NSMutableArrayalloc]initWithObjects:@"ABC",@"DEF",@"ABC",@"ABC",@"QWE",@"TTT",nil];

      for(int i = (int)arr1.count -1 ; i>=0 ; i--)

      {

      NSLog(@"%lu",arr1.count);

      NSString *str = arr1[i];

      if([str isEqualToString:@"ABC"])

      {

      [arr1 removeObjectAtIndex:i];

      }

      }

      for(NSString *strin arr1)

      {

      NSLog(@"%@",str);

      }

      4.使用系统的方法,enumerateObjectsUsingBlock 里面有一个stop 指针,当我们找到对应的str后,使*stop = YES 即可。

      [arr1 enumerateObjectsUsingBlock:^(id _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {

      NSLog(@"%lu",idx);

      if([obj isEqualToString:@"ABC"])

      {

      *stop = YES;

      [arr1 removeObject:obj];

      }

      }];

      二》在循环遍历完之后在进行操作,这种方式主要是遍历找到对应的index,或者说给他添加一个标识符,最后来统一进行删除。

      1.将要删除的字符串放在一个数组里,最后一起删除

      NSMutableArray *arr1 = [[NSMutableArrayalloc]initWithObjects:@"QQQ",@"ABC",@"DEF",@"ABC",@"ABC",@"QWE",@"TTT",nil];

      NSMutableArray *arr = [[NSMutableArrayalloc]init];

      for(NSString *strin arr1)

      {

      if([str isEqualToString:@"ABC"])

      {

      [arr addObject:str];

      break; //如果只删除某一种字符串,那么当找到这个字符串之后就可以结束,不用再找,免得浪费时间,如果要删除不止一个字符串,那么应当找到所有要删除的字符串在进行删除

      }

      }

      [arr1 removeObjectsInArray:arr];

      2.将要删除的字符串所在的下表添加在一个NSMutableIndexSet 中,最后一起删除

      NSMutableArray *arr1 = [[NSMutableArrayalloc]initWithObjects:@"QQQ",@"ABC",@"DEF",@"ABC",@"ABC",@"QWE",@"TTT",nil];

      NSMutableIndexSet *set = [[NSMutableIndexSetalloc]init];

      for(int i =0 ; i < arr1.count ; i++)

      {

      NSString *str = arr1[i];

      if([str isEqualToString:@"ABC"])

      {

      [set addIndex:i];

      }

      }

      [arr1 removeObjectsAtIndexes:set];

      四 :  删除重复元素

      NSMutableArray *result = [NSMutableArray array];
              for (NSString *string in arr) {
                  if (![result containsObject:string]) {
                      [result addObject:string];
                  }
              }

时间: 2024-12-25 03:47:00

iOS数组的去重,判空,删除元素,删除重复元素 等的相关文章

两种方法删除ArrayList里重复元素

方法一: /** List order not maintained **/ public static void removeDuplicate(ArrayList arlList) { HashSet h = new HashSet(arlList); arlList.clear(); arlList.addAll(h); } 方法二: /** List order maintained **/ public static void removeDuplicateWithOrder(Arra

python 删除list中重复元素

list = [1,1,3,4,6,3,7] 1. for s in list: if list.count(s) >1: list.remove(s) 2. list2=[] for s in list: if s not in list2: list2.append(s) print list2 3. list2=[] for s in list: list2.append(s) print list2 python 删除list中重复元素

iOS 数组的去重(普通的无序的去重和排序好的去重)

本文转载至 http://blog.csdn.net/zhaopenghhhhhh/article/details/24972645 有时需要将NSArray中去除重复的元素,而存在NSArray中的元素不一定都是NSString类型.今天想了想,加上朋友的帮助,想到两种解决办法,先分述如下. 1.利用NSDictionary的AllKeys(AllValues)方法 可以将NSArray中的元素存入一个字典,然后利用AllKeys或者AllValues取得字典的所有键或值,这些键或值都是去重的

Python遍历列表删除多个元素或者重复元素

比较容易的是用内置的set l1 = ['b','c','d','b','c','a','a'] l2 = list(set(l1)) print l2 还有一种据说速度更快的,没测试过两者的速度差别 l1 = ['b','c','d','b','c','a','a'] l2 = {}.fromkeys(l1).keys() print l2 这两种都有个缺点,祛除重复元素后排序变了: ['a', 'c', 'b', 'd'] 如果想要保持他们原来的排序: 用list类的sort方法 l1 =

交通银行太平洋信用卡中心的面试题:数组怎么去重?

7种方法实现数组去重 前言 去重是开发中经常会碰到的一个热点问题,不过目前项目中碰到的情况都是后台接口使用SQL去重,简单高效,基本不会让前端处理去重. 那么前端处理去重会出现什么情况呢?假如每页显示10条不同的数据,如果数据重复比较严重,那么要显示10条数据,可能需要发送多个http请求才能够筛选出10条不同的数据,而如果在后台就去重了的话,只需一次http请求就能够获取到10条不同的数据. 当然,这并不是说前端去重就没有必要了,依然需要会熟练使用.本文主要介绍几种常见的数组去重的方法. 方法

LintCode Python 简单级题目 112.删除链表中的重复元素

题目描述: 给定一个排序链表,删除所有重复的元素每个元素只留下一个. 您在真实的面试中是否遇到过这个题? Yes 样例 给出 1->1->2->null,返回 1->2->null 给出 1->1->2->3->3->null,返回 1->2->3->null 标签 链表 题目分析: 给定一个排序链表,删除所有重复的元素每个元素只留下一个. 源码: """ Definition of ListNod

list删除重复元素

方法一:循环元素删除// 删除ArrayList中重复元素public static void removeDuplicate1(List list) {for ( int i = 0 ; i < list.size() - 1 ; i ++ ) {for ( int j = list.size() - 1 ; j > i; j -- ) {if (list.get(j).equals(list.get(i))) {list.remove(j);}}}System.out.println(li

arrayList的合并以及删除重复元素

arrayList的合并: package listTest;//arrayList的合并 import java.util.ArrayList; public class arrayListTest { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub addList(); } private static void addList() { int i

判断数组或者集合中重复元素的个数。

当我们需要对数组或者集合中的元素进行重复元素个数时,我们不妨使用map来完成此操作. 由于map中key是唯一的,所以利用这一特性就可以对数组中重复元素进行统计. java实现代码如下. String[] names={"a","b","a","b","c"}; Map<String,Integer> sameElement=new HashMap<String,Integer>()