NSMutableArray的双条件或多条件排序

本文介绍了如何使用Swift实现优惠卷的双重条件排序,包括主要条件(优惠卷状态)和次要条件(优惠卷消费金额)。通过初级和高级方法分别演示了排序逻辑,包括自定义比较函数和NSSortDescriptor的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近我在研究双条件或多条件排序,当然是有主要条件和次要条件的咯。假设有这么个场景:需要对优惠卷进行双重条件排序,根据优惠卷状态和优惠卷的消费金额进行正序排序,所用代码如下:

先按照优惠卷状态排序,状态一样再按优惠卷消费金额排序.

初级方法:

- (void)sortArr {

    NSMutableArray *customArr = [[NSMutableArrayalloc] init];

    for (NSInteger i =0 ; i < 100; i ++) {

        CustomMode *mode = [[CustomModealloc] init];

        mode.customName = [NSStringstringWithFormat:@"客户%ld",(long)i];

        mode.couponCode = [selfarcdomStr];

        mode.couponPrice = arc4random()%8888 + 1;

        mode.consumeStatus =arc4random()%ConsumeStatus_noRejected;

        [customArr addObject:mode];

    }

    

    NSArray *sortArr =  [customArr sortedArrayUsingComparator:^NSComparisonResult(id _Nonnull obj1, id _Nonnull obj2) {

        CustomMode *mode1 = (CustomMode *)obj1;

        CustomMode *mode2 = (CustomMode *)obj2;

        [@(mode1.consumeStatus)compare:@(mode2.consumeStatus)];

        if (mode1.consumeStatus > mode2.consumeStatus) {

            returnNSOrderedDescending;

        } else if (mode1.consumeStatus == mode2.consumeStatus) {

            return (mode1.couponPrice > mode2.couponPrice);

        } else if (mode1.consumeStatus < mode2.consumeStatus) {

            returnNSOrderedAscending;

        }

        return NSOrderedSame;

    }];

    

    for (CustomMode *modein sortArr) {

        NSLog(@"consumeStatus is %d couponPrice is %f\n\n",mode.consumeStatus,mode.couponPrice);

    }

}

高级方法:

- (void)sortArr1 {

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

    for (NSInteger i = 0 ; i < 100; i ++) {

        CustomMode *mode = [[CustomMode alloc] init];

        mode.customName = [NSString stringWithFormat:@"客户%ld",(long)i];

        mode.couponCode = [self arcdomStr];

        mode.couponPrice = arc4random()%8888 + 1;

        mode.consumeStatus = arc4random()%ConsumeStatus_noRejected;

        [customArr addObject:mode];

    }

    NSDate *date = [NSDate date];

    

    // 1.先按照书名进行排序

    // 这里的key写的是@property的名称

    NSSortDescriptor *statusDesc = [NSSortDescriptor sortDescriptorWithKey:@"consumeStatus" ascending:YES];

    // 2.再按照姓进行排序

    NSSortDescriptor *priceDesc = [NSSortDescriptor sortDescriptorWithKey:@"couponPrice" ascending:YES];

    // 按顺序添加排序描述器

    NSArray *descs = [NSArray arrayWithObjects:statusDesc, priceDesc, nil];

    NSArray *array2 = [customArr sortedArrayUsingDescriptors:descs];

    //        for (CustomMode *mode in array2) {

    //            NSLog(@"\nconsumeStatus is %d couponPrice is %f\n\n",mode.consumeStatus,mode.couponPrice);

    //        }

    NSLog(@"tmv2 is %f",[[NSDate date] timeIntervalSinceDate:date]);

}



代码github地址:https://github.com/songxuhua/TestForAlgorithms



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值