NSArray的各种遍历以及各种排序方法

本文介绍了使用Objective-C对NSArray进行遍历与排序的方法,包括for循环、快速遍历、代码块、迭代器等遍历方式及普通排序、自定义排序、代码块排序和描述法排序等方法。

一、遍历

1.for循环遍历

NSArray *array = [NSArray arrayWithObjects:stu1, @"1", @"2", @"3", nil];  
int count = array.count;  
for (int i = 0; i<count; i++)   
{  
    id obj = [array objectAtIndex:i];  
}  

2.快速遍历
    Student *stu1 = [Student student];
    NSArray *array = [NSArray arrayWithObjects:stu1, @"1", @"2", @"3", nil];
    int i =0;
    for (id obj in array) 
    {
        NSLog(@"%d-%@", i, obj);
        i++;
    }

3.代码块遍历

   Student *stu1 = [Student student];
    NSArray *array = [NSArray arrayWithObjects:stu1, @"1", @"2", @"3", nil];
    [array enumerateObjectsUsingBlock:
     ^(id obj, NSUInteger idx, BOOL *stop) {
         NSLog(@"%ld-%@",idx, obj);
         // 如果索引为1,就停止遍历
         if (idx == 1) {
             // 利用指针修改外面BOOL变量的值
             *stop = YES;
         }
     }];


4.迭代器方法遍历

    Student *stu1 = [Student student];
    NSArray *array = [NSArray arrayWithObjects:stu1, @"1", @"2", @"3", nil];
    // 获取数组的迭代器
    // NSEnumerator *enumerator = [array objectEnumerator];
    // 反序迭代器(从尾部开始遍历元素)
    NSEnumerator *enumerator = [array reverseObjectEnumerator];
    // allObjects是取出没有被遍历过的对象
    NSArray *array2 = [enumerator allObjects];
    NSLog(@"array2:%@", array2);
    // 获取下一个需要遍历的元素
    id obj = nil;
    while (obj = [enumerator nextObject]) {
        NSLog(@"obj=%@", obj);
    }


二、排序

以下数组排序中,如果存放的是NSNumber类型的,例如NSArray *array = [NSArray arrayWithObjects:@245, @33, @1456, @4, nil];则会按照转化为常用类型后的大小排序,但是如果存放的是字符串,例如NSArray *array = [NSArray arrayWithObjects:@"245", @"33", @"1456", @"4", nil];则会先按照第一位大小排序,第一位大小相同的,会按照第二位大小再排,以此类推,下面就简单以字符串为代表罗列以下

1.普通排序

    NSArray *array = [NSArray arrayWithObjects:@"2", @"3", @"1", @"4", nil];
    // 返回一个排好序的数组,原来数组的元素顺序不会改变
    // 指定元素的比较方法:compare:
    NSArray *array2 = [array sortedArrayUsingSelector:@selector(compare:)];
    NSLog(@"array2:%@", array2);

下面的排序需要用到自定义的类型,我们就自定义一个dataaaaa类,添加属性和方法
@property (strong,nonatomic) NSString *money;
@property (strong,nonatomic) NSString *count;

@property (strong,nonatomic) NSNumber *moneyN;
@property (strong,nonatomic) NSNumber *countN;

- (NSComparisonResult)comparedata1:(dataaaaa *)aaa;
- (NSComparisonResult)comparedata2:(dataaaaa *)aaa;

之后在需要排序的地方实例化一个存存放该数据类型的数组

    dataaaaa *a1=[[dataaaaa alloc]init];
    a1.money=@"5";
    a1.count=@"435";
    a1.moneyN=@5;
    a1.countN=@435;
    dataaaaa *a2=[[dataaaaa alloc]init];
    a2.money=@"480";
    a2.count=@"23";
    a2.moneyN=@480;
    a2.countN=@23;
    dataaaaa *a3=[[dataaaaa alloc]init];
    a3.money=@"135";
    a3.count=@"2335";
    a3.moneyN=@135;
    a3.countN=@2335;
    dataaaaa *a4=[[dataaaaa alloc]init];
    a4.money=@"135";
    a4.count=@"17";
    a4.moneyN=@135;
    a4.countN=@17;

2.自定义排序方法
// 指定排序的比较方法  
    //NSArray *array2 = [array sortedArrayUsingSelector:@selector(comparedata1:)];  
    NSArray *array2 = [array sortedArrayUsingSelector:@selector(comparedata2:)];  
    for (dataaaaa *aaa in array2)  
    {  
        NSLog(@"aaa.money==%@  aaa.count==%@",aaa.money,aaa.count);  
    }  

其中comparedata1:和comparedata2:方法的实现和声明是在dataaaa类中实现的

- (NSComparisonResult)comparedata1:(dataaaaa *)aaa  
{  
    // 先按照姓排序  
    NSComparisonResult result = [self.money compare:aaa.money];  
    // 如果有相同的姓,就比较名字  
    if (result == NSOrderedSame) {  
        result = [self.count compare:aaa.count];  
    }  
    return result;  
}  
  
- (NSComparisonResult)comparedata2:(dataaaaa *)aaa  
{  
    // 先按照姓排序  
    NSComparisonResult result = [self.moneyN compare:aaa.moneyN];  
    // 如果有相同的姓,就比较名字  
    if (result == NSOrderedSame) {  
        result = [self.countN compare:aaa.countN];  
    }  
    return result;  
}  

3.代码块方法排序
NSArray *array=@[a1,a2,a3,a4];  
    NSArray *array2 = [array sortedArrayUsingComparator:  
                       ^NSComparisonResult(dataaaaa *obj1, dataaaaa *obj2) {  
                           NSComparisonResult result = [obj1.money compare:obj2.money];  
                           // 如果有相同的姓,就比较名字  
                           if (result == NSOrderedSame) {  
                               result = [obj1.count compare:obj2.count];  
                           }  
  
                           return result;  
                       }];  

4.描述法实现排序
NSArray *array = [NSArray arrayWithObjects:a1,a2,a3,a4,nil];  
    // 先按照money进行排序  
    // 这里的key写的是@property的名称  
    //如果dataaaaa中还有自定义对象databbb,并且需要其字段排序,则可以@"databbb.shuxing",其中shuxing是databbb的@property的名称  
    NSSortDescriptor *moneyasc = [NSSortDescriptor sortDescriptorWithKey:@"money" ascending:YES];  
    //再按照count进行排序  
    NSSortDescriptor *countasc = [NSSortDescriptor sortDescriptorWithKey:@"count" ascending:YES];  
    //按顺序添加排序描述器  
    NSArray *ascs = [NSArray arrayWithObjects:moneyasc,countasc,nil];  
    NSArray *array2 = [array sortedArrayUsingDescriptors:ascs]; 

5.快速排序
void quiksort(int a[],int low,int high)
{
    int i = low;
    int j = high;  
    int temp = a[i]; 
  
    if( low < high)
    {          
        while(i < j) 
        {
            while((a[j] >= temp) && (i < j))
            { 
                j--; 
            }
            a[i] = a[j];
            while((a[i] <= temp) && (i < j))
            {
                i++; 
            }  
            a[j]= a[i];
        }
        a[i] = temp;
        quiksort(a,low,i-1);
        quiksort(a,j+1,high);
    }
    else
    {
        return;
    }
}
 
void main()
{
    int arry[5] = {23,1,21,4,19};
    quiksort(arry,0,4);
    for(i=0;i<5;i++)
    {
        printf("%d ",arr[i]);
    }
    printf("\n");
}

6.冒泡排序(从小到大排序)存在10个不同大小的气泡,由底至上地把较少的气泡逐步地向上升,这样经过遍历一次后,最小的气泡就会被上升到顶(下标为0),然后再从底至上地这样升,循环直至十个气泡大小有序。最重要的思想是两两比较,将两者较少的升上去
#include <stdio.h>  
void swap(int *a, int *b);  
int main()  
{  
    int    array[10] = {15, 225, 34, 42, 52, 6, 7856, 865, 954, 10};  
    int    i, j;  
    for (i = 0; i < 10; i++)  
    {  
        //每一次由底至上地上升  
        for (j = 9; j > i; j--)  
        {  
            if (array[j] < array[j-1])  
            {  
                    swap(&array[j], &array[j-1]);  
            }  
        }  
    }  
    for (i = 0; i < 10; i++)  
    {  
        printf("%d\n", array[i]);  
    }  
    return    0;  
}  
void swap(int *a, int *b)  
{  
    int    temp;  
    temp = *a;  
      *a = *b;  
      *b = temp;  
}  


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值