數組排序

 1 #pragma mark 冒泡排序
 2 - (void)userArrSort:(NSMutableArray *)userArr
 3 {
 4     int n = userArr.count;
 5     int i,j;
 6     NSDictionary *temp;
 7     for(j=0;j<n-1;j++)
 8     {
 9         for(i=0;i<n-1-j;i++)
10         {
11 //            NSDictionary*ssy = [];
12             if(((NSString *)[userArr[i] objectForKey:@"vlevel"]).intValue<((NSString *)[userArr[i+1] objectForKey:@"vlevel"]).intValue)//數組元素大小按升序排列
13             {
14                 temp=userArr[i];
15                 userArr[i]=userArr[i+1];
16                 userArr[i+1]=temp;
17             }
18         }
19     }
20     for (int x = 0; x<userArr.count; x++)
21     {
22         if (1) {
23 //            [userArr replaceObjectAtIndex:0 withObject:[userArr[i]];
24         }
25     }
26 }
27 #pragma mark 已排序數組插入一條數據
28 - (void)insertObjectInUserArr:(NSMutableArray *)userArr withobject:(NSDictionary *)dic
29 {
30     int j;
31     if(((NSString *)[dic objectForKey:@"vlevel"]).intValue<=((NSString *)[userArr[userArr.count - 1] objectForKey:@"vlevel"]).intValue)
32     {
33         [userArr insertObject:dic atIndex:userArr.count];
34     }else
35     {
36         for(int i=0;i<userArr.count;i++)
37         {
38             if(((NSString *)[dic objectForKey:@"vlevel"]).intValue>((NSString *)[userArr[i] objectForKey:@"vlevel"]).intValue)
39             {
40                 j = i;
41                 [userArr insertObject:dic atIndex:j];
42                 break;
43             }
44         }
45     }
46 
47 
48 }

 

 

 

 

(1)直接調用系統的方法排序int數組

NSMutableArray*array = [[NSMutableArrayalloc]init];xcode

[arrayaddObject:[NSNumbernumberWithInt:20]];app

[arrayaddObject:[NSNumbernumberWithInt:1]];less

[arrayaddObject:[NSNumbernumberWithInt:4]];oop

NSArray*sortedArray = [arraysortedArrayUsingSelector:@selector(compare:)];spa

for(inti =0; i < [sortedArraycount]; i++).net

{code

intx = [[sortedArrayobjectAtIndex:i]intValue];對象

NSLog(@"######%d\n", x);blog

}

 

(2)用descriptor方法

#import<Cocoa/Cocoa.h>

 

@interfaceNode: NSObject {

intx;

inty;

intv;

}

 

@property intx;

@property inty;

@property intv;

- (id)init:(int)tx y:(int)ty v:(int)tv;

@end

 

@implementationNode

 

@synthesizex;

@synthesizey;

@synthesizev;

 

- (id)init:(int)tx y:(int)ty v:(int)tv {

x= tx;

y= ty;

v= tv;

return self;

}

 

@end

 

intmain(intargc,char*argv[])

{

NSMutableArray *myMutableArray = [[NSMutableArrayalloc]init];

Node *n[2];

n[0] = [[Nodealloc]init:2y:1v:1];

n[1] = [[Nodealloc]init:4y:2v:2];

 

[myMutableArrayaddObject:n[0]];

[myMutableArrayaddObject:n[1]];

NSSortDescriptor* sortByA = [NSSortDescriptorsortDescriptorWithKey:@"x"ascending:NO];

[myMutableArraysortUsingDescriptors:[NSArrayarrayWithObject:sortByA]];

for(Node*tinmyMutableArray) {

NSLog(@"x === %d", t.x);

NSLog(@"y === %d", t.y);

NSLog(@"v === %d", t.v);

}

}

 

 

(3)自定義重寫方法

/*

 

Abstract:Constants returned by comparison functions, indicating whether a value is equal to, less than, or greater than another value.

Declaration:enumCFComparisonResult{

kCFCompareLessThan= -1,

kCFCompareEqualTo= 0,

kCFCompareGreaterThan= 1

};

*/

#import<Cocoa/Cocoa.h>

@implementation NSNumber (MySort)

- (NSComparisonResult) myCompare:(NSString *)other {

//這裏能夠做適當的修正後再比較

int result = ([selfintValue]>>1) - ([other intValue]>>1);

//這裏能夠控制排序的順序和逆序

return result < 0 ?NSOrderedDescending : result >0 ?NSOrderedAscending :NSOrderedSame;

}

 

@end

int main(int argc, char *argv[])

{

NSMutableArray *array = [[NSMutableArrayalloc]init];

[arrayaddObject:[NSNumbernumberWithInt:20]];

[arrayaddObject:[NSNumbernumberWithInt:1]];

[arrayaddObject:[NSNumbernumberWithInt:4]];

NSArray *sortedArray = [arraysortedArrayUsingSelector:@selector(myCompare:)];

for(int i = 0; i < [sortedArraycount]; i++)

{

int x = [[sortedArrayobjectAtIndex:i]intValue];

NSLog(@"######%d\n", x);

}

}

 

 

 

 

c語言實現的學生成績管理系統是面向過程的,而OC實現的學生成績管理系統則是面向對象的.

對該系統的重難點講述以下:

1.排序.系統中的四個關鍵字分別是 stuID,姓名,年齡,成績.咱們能夠選擇這四種方式並選擇 升降序的方法進行排序.

系統中使用的是  NSmutableArray 存儲數據.那麼如何對對象是類成員的數組排序呢?

先看看NSMutableArray排序的幾種方式.

1)使用@Seletor選擇器調用方法排序.

 

[objc]  view plain copy print ? 在CODE上查看代碼片 派生到個人代碼片
  1. NSMutableArray *array = [[NSMutableArray alloc]init];  
  2.     [array addObject:[NSNumber numberWithInt:10]];  
  3.     [array addObject:[NSNumber numberWithInt:20]];  
  4.     [array addObject:[NSNumber numberWithInt:0]];  
  5.     [array addObject:[NSNumber numberWithInt:1]];  
  6.     [array addObject:[NSNumber numberWithInt:3]];  
  7.     NSLog(@"未排序的數組:%@",array);  
  8.       
  9.     NSArray *sortedArray = [array sortedArrayUsingSelector:@selector(compare:)];  
  10.      NSLog(@"yi排序的數組:%@",sortedArray);  
  11.     /* 
  12.      2013-11-29 08:28:00.616 OC實現學生成績管理系統[451:303] 未排序的數組:( 
  13.      10, 
  14.      20, 
  15.      0, 
  16.      1, 
  17.      3 
  18.      ) 
  19.      2013-11-29 08:28:00.621 OC實現學生成績管理系統[451:303] yi排序的數組:( 
  20.      0, 
  21.      1, 
  22.      3, 
  23.      10, 
  24.      20 
  25.      ) 
  26.      */  

 

 

同時也適用於類對象.

 

[objc]  view plain copy print ? 在CODE上查看代碼片 派生到個人代碼片
  1. //直接實現靜態方法,獲取帶有name和age的Person對象  
  2. +(Person *)personWithAge:(int) age withName:(NSString *)name{  
  3.     Person *person = [[Person alloc] init];  
  4.     person.age = age;  
  5.     person.name = name;  
  6.     return person;  
  7. }  
  8.   
  9. //自定義排序方法  
  10. -(NSComparisonResult)comparePerson:(Person *)person{  
  11.   //默認按年齡排序  
  12.     NSComparisonResult result = [[NSNumber numberWithInt:person.age] compare:[NSNumber numberWithInt:self.age]];//注意:基本數據類型要進行數據轉換  
  13.   //若是年齡同樣,就按照名字排序  
  14.     if (result == NSOrderedSame) {  
  15.         result = [self.name compare:person.name];  
  16.     }  
  17.     return result;  
  18. }  



 


2.高級排序,使用排序描述器:使用descriptor方法對Array中成員是類對象的類型進行按@propery 列進行排序.

  

[objc]  view plain copy print ? 在CODE上查看代碼片 派生到個人代碼片
  1. -(void)SortStudentArray//   
  2. {  
  3.     NSLog(@"按照學號排序請輸入 (id)");  
  4.       
  5.     NSLog(@"按姓名排序請輸入(name)");  
  6.       
  7.     NSLog(@"按照年齡排序請輸入(age)");  
  8.       
  9.     NSLog(@"按照成績排序(score)請輸入:");  
  10.       
  11.     char charKey[10] ;  
  12.     scanf("%s",charKey);  
  13.       
  14.     NSString *tempkey = [NSString stringWithUTF8String:charKey];  
  15.     NSString *key = [tempkey lowercaseString];  
  16.       BOOL ascending = NO;  
  17.     NSLog(@"是否開啓降序模式( 默認不開啓 )?(yes or no):");  
  18.     char ascendingStr[10] ;  
  19.     scanf("%s",ascendingStr);  
  20.     NSString *ascendingKey =[[NSString stringWithUTF8String:ascendingStr] lowercaseString];  
  21.       
  22.     if ([ascendingKey isEqualToString:@"yes"])  
  23.         ascending = YES;  
  24.     else  
  25.         ascending = NO;  
  26.       
  27.       
  28.     if ([key isEqualToString:@"id"]) {  
  29.          
  30.         NSSortDescriptor *sortByID = [NSSortDescriptor sortDescriptorWithKey:@"stuID" ascending:ascending];  
  31.        // 創建NSSortDescriptor 對象,按照的屬性列,是不是asc升序?  
[objc]  view plain copy print ? 在CODE上查看代碼片 派生到個人代碼片
  1.         [studentArray sortUsingDescriptors:[NSArray arrayWithObject:sortByID]];  
  2.         //按照創建的descriptor進行排序.  
  3.     }  
  4.     else if([key isEqualToString:@"name"])  
  5.     {  
  6.         NSSortDescriptor *sortByName= [NSSortDescriptor sortDescriptorWithKey:@"name" ascending:ascending];  
  7.           
  8.         [studentArray sortUsingDescriptors:[NSArray arrayWithObject:sortByName]];  
  9.   
  10.       
  11.     }  
  12.     else if([ key isEqualToString:@"age"])  
  13.     {  
  14.         NSSortDescriptor *sortByAge = [NSSortDescriptor sortDescriptorWithKey:@"age" ascending:ascending];  
  15.           
  16.         [studentArray sortUsingDescriptors:[NSArray arrayWithObject:sortByAge]];  
  17.   
  18.       
  19.     }  
  20.     else if ([key isEqualToString:@"score"])  
  21.     {  
  22.         NSSortDescriptor *sortByScore = [NSSortDescriptor sortDescriptorWithKey:@"score" ascending:ascending];  
  23.           
  24.         [studentArray sortUsingDescriptors:[NSArray arrayWithObject:sortByScore]];  
  25.   
  26.       
  27.     }  
  28.   
  29.   
  30. }  

上述代碼就是我在管理系統中實現的,結果將在系統中呈現.

 

3.自定義重寫方法進行排序.使用Block進行排序.

 

[objc]  view plain copy print ? 在CODE上查看代碼片 派生到個人代碼片
  1. NSArray *array = [NSArray arrayWithObjects:@"1bc",@"4b6",@"123",@"789",@"3ef", nil nil];  
  2.        NSArray *sortedArray = [array sortedArrayUsingComparator:^NSComparisonResult(id obj1, id obj2) {  
  3.              
  4.            //這裏的代碼能夠參照上面compare:默認的排序方法,也能夠把自定義的方法寫在這裏,給對象排序  
  5.            NSComparisonResult result = [obj1 compare:obj2];  
  6.            return result;  
  7.        }];  
  8.        NSLog(@"排序後:%@",sortedArray);  

 

 

2013-11-29 08:42:56.723 OC實現學生成績管理系統[483:303] 排序後:(

    123,

    1bc,

    3ef,

    4b6,

    789

)

相關文章
相關標籤/搜索
本站公眾號
   歡迎關注本站公眾號,獲取更多信息