算法排序---选择排序

//选择排序:首先在未排序序列中找到最小元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小元素,然后放到排序序列末尾。以此类推,直到所有元素均排序完毕

//从第0位置开始,依次让第0位置数据和后面每一个位置数字比较,找出最小的数字,放在第0位置

//依次向后排序

static NSArray * selectSort(NSArray *unsortedArr)

{

NSMutableArray *sortedArr = [NSMutableArray arrayWithArray:unsortedArr];

//排序循环总次数

for (int i = 0; i < sortedArr.count; i ++) {

//取出当前位置的数据,和该数据后面的数据进行大小比较

for (int j = i + 1; j < sortedArr.count; j ++) {

int a = [sortedArr[i] intValue];

int b = [sortedArr[j] intValue];

//如果该位置数据大于其他位置数据,把小的数据放在这个位置,继续拿这个位置的数据和其他数据比较,直到该位置数据为从该位置开始到结束位置中的最小数据

if (b < a) {

[sortedArr exchangeObjectAtIndex:i withObjectAtIndex:j];

}

}

}

return sortedArr;

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 总结一下常见的排序算法。 排序分内排序和外排序。内排序:指在排序期间数据对象全部存放在内存的排序。外排序:指在排序...
    jiangliang阅读 1,520评论 0 1
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 5,303评论 0 52
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 3,829评论 0 15
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 34,801评论 18 399
  • 有没有这么一小伙伴,本来想畅写一下内心的文字,敲打键盘时发现穷词了,内心想法千千万,苦于不知道如何表达是好,写...
    梦若然阅读 394评论 0 1

友情链接更多精彩内容