Swift 归并排序
来源:互联网 发布:苹果视频制作软件 编辑:程序博客网 时间:2024/06/03 20:38
用Swift写的一个归并排序算法(递归法)
func Merge(sourceArray: NSMutableArray, tempArray: NSMutableArray, startIndex: Int, midIndex: Int, endIndex: Int) { var i = startIndex var j = midIndex + 1 var k = startIndex while(i != midIndex+1 && j != endIndex+1) { let one = sourceArray[i] as! Int let two = sourceArray[j] as! Int if one >= two { tempArray.insertObject(sourceArray[j], atIndex: k) j += 1 k += 1 }else { tempArray.insertObject(sourceArray[i], atIndex: k) i += 1 k += 1 } } while(i != midIndex+1) { tempArray.insertObject(sourceArray[i], atIndex: k) i += 1 k += 1 } while(j != endIndex+1) { tempArray.insertObject(sourceArray[j], atIndex: k) j += 1 k += 1 } for i in startIndex...endIndex { sourceArray.replaceObjectAtIndex(i, withObject: tempArray[i]) }} func MergeSort(sourceArray: NSMutableArray, tempArray: NSMutableArray, startIndex: Int, endIndex: Int) { var midIndex = 0 if startIndex < endIndex { midIndex = (startIndex + endIndex)/2 MergeSort(sourceArray, tempArray: tempArray, startIndex: startIndex, endIndex: midIndex) MergeSort(sourceArray, tempArray: tempArray, startIndex: midIndex+1, endIndex: endIndex) Merge(sourceArray, tempArray: tempArray, startIndex: startIndex, midIndex: midIndex, endIndex: endIndex) }}
从小到大排列。
6 0
- Swift 归并排序
- (Swift 实现)排序 —— 归并排序
- 归并排序-归并排序
- 归并和归并排序
- 归并与归并排序
- 归并排序
- 归并排序
- 归并排序
- 归并排序
- 归并排序
- 归并排序
- 排序::归并
- 归并排序
- 归并排序
- 归并排序
- 归并排序
- 归并排序
- 归并排序
- Lesson 3 Nehe
- 数据库作业的执行
- 如何通过外部事件将gridview中的编辑状态变为显示状态
- js通过提交过来的表单获取表单中的指定数据
- jquery的each()详细介绍
- Swift 归并排序
- CacheDependency用法
- 2014年05月19日
- 伪静态软件下载连接
- sql server存储过程基础
- Spark中实现TOP N (Scala版本)
- mssql存储过程的一个例子
- js重定向---实现页面跳转的几种方式
- .net关于dropdowlist操作