| |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| -> 移动开发 -> 用 Kotlin 实现归并排序 -> 正文阅读 |
|
|
[移动开发]用 Kotlin 实现归并排序 |
package liwen.zhao
class MergeSort(){
/**
* 通过递归,将集合左右两部分不断一分为二,然后进行排序合并
*/
private fun dichotomyAndmergeSort(arrayList: ArrayList<Int>,l:Int,r:Int){
if(r-l<=0)
return
var mid = (l+r)/2
dichotomyAndmergeSort(arrayList,l,mid) // 集合左边
dichotomyAndmergeSort(arrayList,mid+1,r) // 集合右边
merge(arrayList,l,mid,r)
}
private fun merge(arrayList: ArrayList<Int>, l: Int, mid: Int, r: Int) {
var arrayListCopy: ArrayList<Int> = ArrayList()
for(c in l..r){
arrayListCopy.add(arrayList.get(c))
}
var i = l
var j = mid + 1
for (k in l..r){
if(i>mid){
arrayList.set(k,arrayListCopy.get(j-l))
j++
continue
}else if(j>r){
arrayList.set(k,arrayListCopy.get(i-l))
i++
continue
}
if(arrayListCopy.get(i-l)<arrayListCopy.get(j-l)){
arrayList.set(k,arrayListCopy.get(i-l))
i++
}else{
arrayList.set(k,arrayListCopy.get(j-l))
j++
}
}
}
fun mergeSort(arrayList: ArrayList<Int>){
dichotomyAndmergeSort(arrayList,0,arrayList.size-1)
}
}
fun main(){
var mergeSortObj = MergeSort()
var arrlist = arrayListOf(1,23,34,0,2,23,15,4,34)
mergeSortObj.mergeSort(arrlist)
print(arrlist)
}
|
|
|
| 移动开发 最新文章 |
| Vue3装载axios和element-ui |
| android adb cmd |
| 【xcode】Xcode常用快捷键与技巧 |
| Android开发中的线程池使用 |
| Java 和 Android 的 Base64 |
| Android 测试文字编码格式 |
| 微信小程序支付 |
| 安卓权限记录 |
| 知乎之自动养号 |
| 【Android Jetpack】DataStore |
|
|
| 上一篇文章 下一篇文章 查看所有文章 |
|
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
| 360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年11日历 | -2025/11/29 15:28:21- |
|
| 网站联系: qq:121756557 email:121756557@qq.com IT数码 |