对数组进行排序(不写compare:方法)
NSArray *sortedArray = [array sortedArrayUsingComparator: ^(id obj1, id obj2) {
if ([obj1 integerValue] > [obj2 integerValue]) {
return (NSComparisonResult)NSOrderedDescending;
}
if ([obj1 integerValue] < [obj2 integerValue]) {
return (NSComparisonResult)NSOrderedAscending;
}
return (NSComparisonResult)NSOrderedSame;
}];
以前只用过[array sortedArrayUsingSelector:@selector(compare:)];方法,若没有现成的compare:方法还要自己写一个新的比较方法,比较麻烦.
在研究对数组逆向排序时看到了这个方法,貌似是4.0新出的blocks.(Block, 简单的说,就是一个函数对象,和其它类型的对象一样,你可以创建它,可以赋给一个变量,也可以作为函数的参数来传递)
blocks传送门:http://www.cocoachina.com/macdev/objc/2010/0601/1591.html
用法:若sortedArray存的数据是Person类的对象,(name,age,address...),要以age排序,即将上面方法中的[obj1 intergerValue] 改为[obj1/2 age]即可;或 要倒序排列,则将NSOrderedDescending和NSOrderedAscending调换.
分享到:
相关推荐
要求:不提供单独的升序和降序排序方法(不分别定义一个升序和一个降序方法),而只提供一个排序方法SortArray(),它接受一个委托类型的参数compare,该参数会引用要使用的比较方法。为执行降序排序,向排序方法...
JavaScript数组sort()方法排序数组的元素。 语法 array.sort( compareFunction ); 下面是参数的详细信息: compareFunction : 指定一个函数,定义排序次序。如果省略,数组字典顺序排序。 返回值: 返回一个排序的...
我们来看看MDN官方解释 arr.sort([compareFunction])compareFunction(Optional),Specifies a fu
在日常的代码开发中,关于数组排序的操作可不少,JavaScript 中可以调用 sort 方法对数组进行快速排序。 今天,就数组的 sort 方法来学习一下,避免日后踩坑的悲惨遭遇。 sort 方法用于对数组的元素进行排序。 ...
1.6kB),通过区分Unicode字符,数字,日期等来对数组和集合进行自然排序。 人们对包含数字的字符串进行排序的方式与大多数排序算法不同,后者通过按Unicode代码点顺序比较字符串来对值进行排序。 这会产生与人的...
C#中Linq查询基本操作使用实例c#中LINQ的基本用法实例C# linq查询之动态OrderBy用法实例C#中的Linq Intersect与Except方法使用实例C#中的Linq to Xml详解LINQ 标准查询操作符linq语法基础使用示例C#使用linq对数组...
比如对一个数组进行排序,程序员可以写如下排序算法: 代码演示:数组排序 public static void sort(int[] arrs) { boolean isSwap = false; for (int i = 0; i ; i++) { isSwap = false; for (int j = arrs....
因为在Java库函数里,PriorityQueue是基于小堆建立的,所以当我们需要大堆的时候需要对它进行改建。 方法一: static class com implements Comparator { //定义一个静态内部类,继承Comparator接口,并重写他的...
判断是否为数组.asp 判断是否为数组 判断是否为日期.asp 判断是否为日期 判断是否为空.asp 判断是否为空 判断是否为空值.asp 判断是否为空值 获取变量类型信息.asp ...
写一个函数,例如:给你的 a b c 则输出 abc acb bac bca cab cba import java.util.ArrayList; import java.util.List; public class NumTest { public static void main(String[] args) { String s="ABCD";...