美文网首页
基金项目中遇到的两种排序

基金项目中遇到的两种排序

作者: 苍茫的天涯 | 来源:发表于2018-09-12 16:11 被阅读15次

这次做的关于基金的项目里有比较多的排序需求,这里简单的把我遇到的几种情况总结一下,方便以后查阅。

升序降序排列数据

升序降序主要是利用NSArray的sortedArrayUsingComparator来实现,通过循环数组中的元素来对数组进行重新排序

- (NSArray<ObjectType> *)sortedArrayUsingComparator:(NSComparator NS_NOESCAPE)cmptr API_AVAILABLE(macos(10.6), ios(4.0), watchos(2.0), tvos(9.0));

例如给 1,3,5,2,6,7,8,3,5,7,6,7,1,2,9 排序,分别使用得到他们的升序和降续,例子如下:

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
    NSArray *array = @[@"1",@"3",@"5",@"2",@"6",@"7",@"8",@"3",@"5",@"7",@"6",@"7",@"1",@"2",@"9"];
    [self arraySortASCWithArray:array];
    [self arraySortDESCWithArray:array];
}
#pragma mark -- 数组排序方法(升序:从小到大)
- (NSArray *)arraySortASCWithArray:(NSArray *)array {
    NSArray *result = [array sortedArrayUsingComparator:^NSComparisonResult(NSString *obj1, NSString *obj2) {
        return [@(obj1.floatValue) compare:@(obj2.floatValue)];
    }];
    return result;
}
#pragma mark -- 数组排序方法(降序:从大到小)
- (NSArray *)arraySortDESCWithArray:(NSArray *)array {
    NSArray *result = [array sortedArrayUsingComparator:^NSComparisonResult(NSString *obj1, NSString *obj2) {
        return [@(obj2.floatValue) compare:@(obj1.floatValue)];
    }];
    return result;
}

根据已有的排列顺序对所得数组进行排序

这个需求是在已有一个默认排序的前提下给一个不确定的数组进行排序,例如对基金类型进行排序,基金的类型常见的有混合型,股票型,指数型,债券型,货币型,封闭型。已知这个默认的顺序,然后对服务端给的数据进行排序,例子如下:

- (void)viewDidLoad {
    [super viewDidLoad];
    NSDictionary *dic1 = @{@"指数型":@"基金1"};
    NSDictionary *dic2 = @{@"混合型":@"基金2"};
    NSDictionary *dic3 = @{@"混合型":@"基金3"};
    NSDictionary *dic4 = @{@"封闭型":@"基金4"};
    NSDictionary *dic5 = @{@"股票型":@"基金5"};
    NSDictionary *dic6 = @{@"AA型":@"基金6"};
    NSDictionary *dic7 = @{@"货币型":@"基金7"};
    NSDictionary *dic8 = @{@"货币型":@"基金8"};
    NSDictionary *dic9 = @{@"指数型":@"基金9"};
    NSDictionary *dic10 = @{@"BB型":@"基金10"};
    NSDictionary *dic11 = @{@"货币型":@"基金11"};
    NSDictionary *dic12 = @{@"股票型型":@"基金12"};
    NSArray *fundArray = @[dic1,dic3,dic2,dic11,dic12,dic3,dic4,dic5,dic6,dic7,dic7,dic9,dic5,dic8,dic11,dic10,dic2];
    NSLog(@"_________%@",[self getFundTypeArrayWithDataArray:fundArray]);
}

- (NSMutableArray *)getFundTypeArrayWithDataArray:(NSArray *)dataArray {
    NSMutableArray *filterArray = [NSMutableArray array];

    NSMutableDictionary *allArrayDic = [NSMutableDictionary new];
    for (NSDictionary *dic in dataArray) {
        NSString *type = dic.allKeys[0];
        if ([allArrayDic.allKeys containsObject:type]) {
            NSMutableArray *array = allArrayDic[type];
            [array addObject:dic];
            [allArrayDic setObject:array forKey:type];
        } else {
            NSMutableArray *array = [NSMutableArray new];
            [array addObject:dic];
            [allArrayDic setObject:array forKey:type];
        }
    }
    
    NSArray *defaultArray = @[@"混合型",@"股票型",@"指数型",@"债券型",@"货币型",@"封闭型"];
    
    for (NSString *fundTypeStr in defaultArray) {
        if ([allArrayDic.allKeys containsObject:fundTypeStr])  {
            NSArray *fundArray = allArrayDic[fundTypeStr];
            [filterArray addObject:fundArray];
            [allArrayDic removeObjectForKey:fundTypeStr];
        }
    }
    // 把剩下非排列基金的直接放进去
    for (NSString *keystr in allArrayDic.allKeys) {
        NSArray *fundArray = allArrayDic[keystr];
        [filterArray addObject:fundArray];
    }
    
    return filterArray;
}


正常情况下都是用model来代替这个dic,不过篇幅限制,就直接用字典来表示了

相关文章

  • 基金项目中遇到的两种排序

    这次做的关于基金的项目里有比较多的排序需求,这里简单的把我遇到的几种情况总结一下,方便以后查阅。 升序降序排列数据...

  • 关于一些算法和时间/空间复杂度

    排序的分类可以分为两种:内排序和外排序。 在排序过程中,全部记录放在内存,则称为内排序,如果排序过程中要使用外村,...

  • javascript实现排序算法(三)

    前两篇博客介绍了排序算法中的交换排序中的冒泡排序和快速排序。虽然两种排序都属于交换排序,但是这两个排序的时间复杂度...

  • 排序算法对比、总结(Python代码)

    排序大的分类可以分为两种:内排序和外排序。在排序过程中,全部记录存放在内存,则称为内排序,如果排序过程中需要使用外...

  • 【Java】各类排序算法

    排序大的分类可以分为两种:内排序和外排序。在排序过程中,全部记录存放在内存,则称为内排序,如果排序过程中需要使用外...

  • 归并排序

    排序分 内部排序 + 外部排序 两种, 区分在于数据量, 内部排序可以将数据全部放到内存中, 然后进行排序常见的内...

  • 排序算法整理

    排序算法总览 排序大的分类可以分为两种:内排序和外排序。在排序过程中,全部记录存放在内存,则称为内排序,如果排序过...

  • Arrays.sort使用的排序算法

    直接开门见山 java中Arrays.sort使用了两种排序方法,快速排序和优化的归并排序。 快速排序主要是对哪些...

  • Excel怎么使用?-编辑

    Excel编辑中的排序和筛选、查找和选择也是工作中比较常用的功能。 1.排序和筛选 排序 排序有升序和降序两种(按...

  • 归并排序算法实现

    排序算法是最常见,最基础的算法,作者文集中记录了两种排序算法(插入排序,归并排序) 归并排序实现原理是切刀流,先中...

网友评论

      本文标题:基金项目中遇到的两种排序

      本文链接:https://www.haomeiwen.com/subject/bftbgftx.html