当前位置:小鱼儿玄机二站 > 操作系统 > 数组排序3种办法

数组排序3种办法

文章作者:操作系统 上传时间:2019-11-11

Object-C,NSArraySortTest,数组排序3种方式

晚上回来,继续写Object-C的例子,今天不打算写iOS可视化界面的程序,太累了。

刚刚dady又电话过来,老一套,烦死了。

其实,我一直一个观点,无论发生什么事情,不要整天一副不开心的样子。

开开心心过日子,活着就要懂得珍惜。

 

刚刚写了数组排序,有3种方法,使用对象自带的compare方法、传入比较函数、匿名函数-代码块。

个人认为,本质是2种方法。

一种是,类似Java中的对象,实现Comparable接口的compareTo方法。

一种是,传入比较器Comparator,比较灵活。

 

代码

 

//
//  main.m
//  NSArraySort
//
//  Created by fansunion on 15/12/2.
//  Copyright (c) 2015年 demo. All rights reserved.
//

#import 

//需要定义在main函数之前,和C语言一样,和java不一样
//比较函数,降序排列
NSComparisonResult intSort(id a,id b,void* context){
    int v1 =  [a intValue];
    int v2 = [b intValue];
    if(v1 > v2){
        return NSOrderedAscending;
    }else if(v1 < v2){
        return NSOrderedDescending;
    }else{
        return NSOrderedSame;
    }
}

int main(int argc, const char * argv[]) {
    @autoreleasepool {
        //字符串数组,使用自带的compare方法排序。相当于Java中对象实现Comparable接口的compareTo方法
        NSArray* strArray = @[@"Java",@"Android",@"Object-C"];
        strArray = [strArray sortedArrayUsingSelector:@selector(compare:)];
        NSLog(@("%@"),strArray);
        //整型数组,传入比较函数。相当于Java中传入Comparator对象,这种方式更加灵活。
        NSArray* numberArray [email protected][[NSNumber numberWithInteger:2015],[NSNumber numberWithInt:1949],[NSNumber numberWithInt:2020]];
        numberArray = [numberArray sortedArrayUsingFunction:intSort context:nil];
        NSLog(@"%@",numberArray);
        //使用代码块比较,进行排序(和第2种方法感觉没啥区别啊),升序
        NSArray* numberArrayAsc =[numberArray sortedArrayUsingComparator:^(id a,id b){
            int v1 = [a intValue];
            int v2 = [b intValue];
            if(v1 > v2){
                return NSOrderedDescending;
            }else if(v1 < v2){
                return NSOrderedAscending;
            }else{
                return NSOrderedSame;
            }
        }];
        NSLog(@"%@",numberArrayAsc);
    }
    return 0;
}

 

程序输出

 

2015-12-02 20:39:09.500 NSArraySort[5534:380948] (

Android,

Java,

"Object-C"

)

2015-12-02 20:39:09.502 NSArraySort[5534:380948] (

2020,

2015,

1949

)

2015-12-02 20:39:09.502 NSArraySort[5534:380948] (

1949,

2015,

2020

)

Program ended with exit code: 0

晚上回来,继续写Object-C的例子,今天不打算写iOS可视化界面的程序,太累了。 刚刚dady又电话过来,...

Object-C,数组NSArray

晚上回来,写了2个iOS应用程序。

就是在界面中,展示标签。一种是手动构造界面,然后绑定事件。另外一种是,使用自带的界面作为容器,但是手动向里面放其它界面元素。

 

书中的观点是,使用图形化界面,构造界面比较好。

 

然后,又写了个Object-C数组的例子。

 

Object-C相对简单一些,黑屏控制台输出,而iOS可视化界面的程序,代码较多,也不好描述。

iOS程序的“上下文环境”更复杂一些把,而Object-C语言,和Java就类似。

 

 

//
//  main.m
//  NSArrayTest
//
//  Created by fansunion on 15/12/1.
//  Copyright (c) 2015年 demo. All rights reserved.
//

#import 

//演示不可变数组
int main(int argc, const char * argv[]) {
    @autoreleasepool {
        //不可变数组,用类方法构造数组
        NSArray* array =[NSArray arrayWithObjects:@"A",@"B",@"C",nil];
        //访问元素有2种方式
        NSLog(@"The first element is %@",array[0]);
        NSLog(@"The second element is %@",[array objectAtIndex:1]);

        //不可变数组,在原来的基础上再增加一个元素D返回心的数组
        NSArray* newArray = [array arrayByAddingObject:@"D"];
        //使用for循环,打印新的数组
        for(int index=0;index   程序输出 2015-12-01 21:16:55.768 NSArrayTest[5346:358824] The first element is A2015-12-01 21:16:55.769 NSArrayTest[5346:358824] The second element is B2015-12-01 21:16:55.769 NSArrayTest[5346:358824] The 0 element is A2015-12-01 21:16:55.769 NSArrayTest[5346:358824] The 1 element is B2015-12-01 21:16:55.770 NSArrayTest[5346:358824] The 2 element is C2015-12-01 21:16:55.770 NSArrayTest[5346:358824] The 3 element is D2015-12-01 21:16:55.774 NSArrayTest[5346:358824] The element is A2015-12-01 21:16:55.774 NSArrayTest[5346:358824] The element is B2015-12-01 21:16:55.774 NSArrayTest[5346:358824] The element is C2015-12-01 21:16:55.774 NSArrayTest[5346:358824] The element is DProgram ended with exit code: 0 需要特别指出的是,NSArray是不可变的,就像java中的String对象。NSMutableArray是可变数组。 这点和java中正好相反:Java中的ArrayList正好是可变的,如果想要不可变的,Apache等第三方有实现。

晚上回来,写了2个iOS应用程序。 就是在界面中,展示标签。一种是手动构造界面,然后绑定事件。另外一种是,使用自带...

本文由小鱼儿玄机二站发布于操作系统,转载请注明出处:数组排序3种办法

关键词: