zoukankan      html  css  js  c++  java
  • 数组去重复

    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.手动去重

    用眼看着,一个一个挑选出来,重新输入计算机(开个玩笑)
  • 相关阅读:
    .NET 环境中使用RabbitMQ
    WPF窗口模板——Style样式
    C#获取当前日期时间
    C#解析JSON字符串总结
    c#简单加密和对称加密
    List<T>转换为二维数组
    java后台导出pdf
    C# 创建 读取 更新 XML文件
    python 第三天
    编写登录接口
  • 原文地址:https://www.cnblogs.com/isItOk/p/5215543.html
Copyright © 2011-2022 走看看