一: 去重

有时需要将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]];

}

}

顺序就不会乱了。

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

  1. if (array != nil)

或是:

    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];
                  }
              }

      五: 排序  model排序

          [_historyNoticeModel.content  sortUsingComparator:^NSComparisonResult(HistoryItemNotices*   _Nonnull obj1, HistoryItemNotices  * _Nonnull obj2) {

              if(obj2.isNew < obj1.isNew){

                  returnNSOrderedAscending;

              }

              returnNSOrderedDescending;

          }];

iOS数组的去重,判空,删除元素,删除重复元素 model排序 等的更多相关文章

  1. Java 删除ArrayList中重复元素,保持顺序

    // 删除ArrayList中重复元素,保持顺序          public static List<Map<String, Object>> removeDuplicat ...

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

    本文转载至 http://blog.csdn.net/zhaopenghhhhhh/article/details/24972645 有时需要将NSArray中去除重复的元素,而存在NSArray中的 ...

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

    在遍历list的时候,删除符合条件的数据,结果不符合预期   num_list = [1, 2, 2, 2, 3] print(num_list) for item in num_list: if i ...

  4. 删除列表中重复元素以及求list中元素个数

    Python 去除列表中重复的元素 来自比较容易记忆的是用内置的set l1 = ['b','c','d','b','c','a','a'] l2 = list(set(l1)) print l2 还 ...

  5. 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 ...

  6. java 对一个字符串去重,即去掉字符串内重复元素

    String str ="abc|efa|abc|efa|abc"; String str1 = str.replaceAll("(?s)(.)(?=.*\\1)&quo ...

  7. 218。重复元素II(重复元素的下标差值<=K)(哈希)

    给定一个整数数组和一个整数 k,判断数组中是否存在两个不同的索引 i 和 j,使得 nums [i] = nums [j],并且 i 和 j 的差的 绝对值 至多为 k. 示例 1: 输入: nums ...

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

    arrayList的合并: package listTest;//arrayList的合并 import java.util.ArrayList; public class arrayListTest ...

  9. python列表删除重复元素的三种方法

    给定一个列表,要求删除列表中重复元素. listA = ['python','语','言','是','一','门','动','态','语','言'] 方法1,对列表调用排序,从末尾依次比较相邻两个元素 ...

随机推荐

  1. Spring MVC工作流程图

    图一   图二    Spring工作流程描述       1. 用户向服务器发送请求,请求被Spring 前端控制Servelt DispatcherServlet捕获:       2. Disp ...

  2. 实现ModelDriver接口的功能(转)

    ModelDriver接口 来自com.opensymphony.xwork2.ModelDriven.是xwork-2.1.2-750.jar包的东西. 下面是源码: package com.ope ...

  3. java如何实现Socket的长连接和短连接

    讨论Socket必讨论长连接和短连接 一.长连接和短连接的概念 1.长连接与短连接的概念:前者是整个通讯过程,客户端和服务端只用一个Socket对象,长期保持Socket的连接:后者是每次请求,都新建 ...

  4. [小问题笔记(十)] SQL Server 里 float 转 varchar等字符类型 不使用科学计数法

    需要转换两次, 试了一下 float 转 bigint 转 varchar 溢出了... 后来用  float 转 decimal(38,0) 转 varchar 就成功了~ ,)) )) 另吐槽一下 ...

  5. [小问题笔记(三)] SVN树冲突(Tree Conflict),文件不能提交的解决办法

    传说中SVN的树冲突是由不同开发者删除文件,移动文件神马的造成的. 我们遇到的情况是: 开发人员小B移动了项目中几个文件然后提交.开发人员小L更新项目至最新版本. 获取到移动后的文件则显示文件已被修改 ...

  6. CALL_AND_RETRY_LAST Allocation failed node打包报错

    全局安装increase-memory-limit: npm install -g increase-memory-limit 进入工程目录,执行: increase-memory-limit

  7. IIS服务器管理学习

    工欲善其事必先利其器 首先给服务器配上强力的软件,用于安全防护和监控. 公司服务器用的阿里云的ECS,已经有防护和监控了,之后又选择额外加了一个安全狗 为了监控服务器上系统的各项运行指标,又买了听云平 ...

  8. c语言memset源码

    c语言memset源码 一.用法 void *memset(void *s, int ch, size_t n);作用:将s所指向的某一块内存中的每个字节的内容全部设置为ch指定的ASCII值, 块的 ...

  9. 为什么U盘在拔出之前需要“安全弹出”?

    前言 我们不知道从什么时候开始有一个观念:U盘一定要点击“安全弹出”才能拔.那么是不是在任何情况下都必须要这样呢? 介绍 U盘的传输策略有两种: 写入缓存:这种策略在windows中称为“更好的性能” ...

  10. python的os.urandom 的用途

    Python中os.urandom(n)的作用 随机产生n个字节(0-255)的字符串,可以作为随机加密key使用~ >>> index = os.urandom(2) >&g ...