快速排序
Posted 唐宋元明清。
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了快速排序相关的知识,希望对你有一定的参考价值。
#import "ViewController.h" @interface ViewController () @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typically from a nib. NSMutableArray *arr = @[@"9", @"8", @"2", @"6", @"1"].mutableCopy; [self QuickSort:arr StartIndex:0 EndIndex:4]; NSLog(@"%@", arr); } -(void)QuickSort:(NSMutableArray *)list StartIndex:(NSInteger)startIndex EndIndex:(NSInteger)endIndex{ if(startIndex >= endIndex)return; NSNumber * temp = [list objectAtIndex:startIndex]; NSInteger tempIndex = startIndex; //临时索引 处理交换位置(即下一个交换的对象的位置) for(int i = (int)startIndex + 1 ; i <= endIndex ; i++){ NSNumber *t = [list objectAtIndex:i]; if([temp intValue] > [t intValue]){ tempIndex = tempIndex + 1; [list exchangeObjectAtIndex:tempIndex withObjectAtIndex:i]; } } [list exchangeObjectAtIndex:tempIndex withObjectAtIndex:startIndex]; [self QuickSort:list StartIndex:startIndex EndIndex:tempIndex-1]; [self QuickSort:list StartIndex:tempIndex+1 EndIndex:endIndex]; } - (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning]; // Dispose of any resources that can be recreated. } @end
打印结果
2016-12-22 17:56:14.546 text[31326:1735436] (
1,
2,
6,
8,
9
)
以上是关于快速排序的主要内容,如果未能解决你的问题,请参考以下文章