Kotlin实现LeetCode算法题之Median of Two Sorted Arrays
题目Median of Two Sorted Arrays(难度Hard)

方案1,数组合并&排序调用Java方法
import java.util.*
class Solution {
fun findMedianSortedArrays(nums1: IntArray, nums2: IntArray): Double {
val lenNums1 = nums1.size
val lenNums2 = nums2.size
val array = Arrays.copyOf(nums1, lenNums1 + lenNums2)
System.arraycopy(nums2, , array, lenNums1, lenNums2)
Arrays.sort(array)
var median: Double
val lenArray = array.size
== ) {
median = array[(lenArray - ) / ].toDouble()
} else {
median = (array[(lenArray - ) / ] + array[lenArray / ]).toDouble() /
}
return median
}
}
提交详情1

平均耗时0.25ms。
方案2,数组合并&排序调用Kotlin方法
class Solution {
fun findMedianSortedArrays(nums1: IntArray, nums2: IntArray): Double {
val lenNums1 = nums1.size
val lenNums2 = nums2.size
val array = IntArray(lenNums1 + lenNums2)
System.arraycopy(nums1, , array, , lenNums1)
System.arraycopy(nums2, , array, lenNums1, lenNums2)
array.sort()
var median: Double
val lenArray = array.size
== ) {
median = array[(lenArray - ) / ].toDouble()
} else {
median = (array[(lenArray - ) / ] + array[lenArray / ]).toDouble() /
}
return median
}
}
提交详情2

平均耗时0.27ms。
Java & Kotlin代码对比
其实,通过源码可以发现,方案1和2在对数组进行合并与排序时调用的方法是一样的。
Arrays.java
public static int[] copyOf(int[] original, int newLength) {
int[] copy = new int[newLength];
System.arraycopy(original, , copy, ,
Math.min(original.length, newLength));
return copy;
}
copyOf方法内部调用的还是System的静态方法arraycopy(native就不往下追了)。
System.java
public static native void arraycopy(Object src, int srcPos,
Object dest, int destPos,
int length);
Arrays.kt
/** * Creates a new array of the specified [size], where each element is calculated by calling the specified * [init] function. The [init] function returns an array element given its index. */ public inline constructor(size: Int, init: (Int) -> Int)
IntArray(size: Int)会生成一个大小为size,元素值由init方法利用下标值计算而来,如果init不传入,那么默认均为0。
Arrays.kt
public fun IntArray.sort(): Unit {
) java.util.Arrays.sort(this)
}
Kotlin中IntArray的扩展方法sort,内部调用的是Java中Arrays的sort方法。
Arrays.java
public static void sort(int[] a) {
DualPivotQuicksort.sort(a, , a.length - , , );
}
Arrays的sort方法最终是通过快排来实现的。而快速排序的时间复杂度为O(nlog(n)),但是题目要求量级为O(log(m+n))。
方案3,分治法求中位数
class Solution {
fun findMedianSortedArrays(nums1: IntArray, nums2: IntArray): Double {
var media1: Int
val len1 = nums1.size
val len2 = nums2.size
== ) {
media1 = getMedian(nums1, nums2, , len1 - , , len2 - , (len1 + len2) / + )
return media1 / 1.0
} else {
media1 = getMedian(nums1, nums2, , len1 - , , len2 - , (len1 + len2) / )
media2 = getMedian(nums1, nums2, , len1 - , , len2 - , (len1 + len2) / + )
return (media1 + media2) / 2.0
}
}
fun getMedian(nums1: IntArray, nums2: IntArray, s1: Int, n1: Int, s2: Int, n2: Int, k: Int): Int {
val x = (s1 + n1) /
val y = (s2 + n2) /
if (s1 > n1)
]
if (s2 > n2)
]
return if (nums1[x] <= nums2[y]) {
) {
getMedian(nums1, nums2, s1, n1, s2, y - , k)
} else {
getMedian(nums1, nums2, x + , n1, s2, n2, k - (x - s1) - )
}
} else {
) {
getMedian(nums1, nums2, s1, x - , s2, n2, k)
} else {
getMedian(nums1, nums2, s1, n1, y + , n2, k - (y - s2) - )
}
}
}
}
提交详情3

平均耗时0.32ms。
结果分析
但从LeetCode的测试用例所消耗的时间来看,上述三种方案没有明显的区别,理论上分治法的时间复杂度为O(log(n))。
Kotlin实现LeetCode算法题之Median of Two Sorted Arrays的更多相关文章
- 算法题之Median of Two Sorted Arrays
这道题是LeetCode上的题目,难度级别为5,刚开始做没有找到好的思路,以为是自己智商比较低,后来发现确实也比较低... 题目: There are two sorted arrays nums1 ...
- leetcode第四题:Median of Two Sorted Arrays (java)
Median of Two Sorted Arrays There are two sorted arrays A and B of size m and n respectively. Find t ...
- 刷题4. Median of Two Sorted Arrays
一.题目 Median of Two Sorted Arrays,具体请自行搜索. 这个题目,我看了一下,经过一番思考,我觉得实现起来不是很复杂. 但要做到bug free也不难,最大的问题是性能问题 ...
- Kotlin实现LeetCode算法题之Two Sum
LeetCode介绍 LeetCode是算法练习.交流等多功能网站,感兴趣的同学可以关注下(老司机请超车).页面顶部的Problems菜单对应算法题库,附带历史通过滤.难易程度等信息. 未来计划 打算 ...
- 【LeetCode每天一题】Median of Two Sorted Arrays(两数组中的中位数)
There are two sorted arrays nums1 and nums2 of size m and n respectively. Find the median of the tw ...
- 【LeetCode】4、Median of Two Sorted Arrays
题目等级:Hard 题目描述: There are two sorted arrays nums1 and nums2 of size m and n respectively. Find t ...
- LeetCode(4)Median of Two Sorted Arrays
题目 There are two sorted arrays nums1 and nums2 of size m and n respectively. Find the median of the ...
- LeetCode解题笔记 - 4. Median of Two Sorted Arrays
There are two sorted arrays nums1 and nums2 of size m and n respectively. Find the median of the two ...
- LeetCode 笔记系列一 Median of Two Sorted Arrays
题目:There are two sorted arrays A and B of size m and n respectively. Find the median of the two sort ...
随机推荐
- 文件上传之--内存溢出(System.OutOfMemoryException)
两周前就想把这点经验记录下来了,由于拖延症上身,直到刚才突然想起这件未完成的任务,今天是1024,在这个特别的日子里,祝所有程序猿兄弟姐妹们节日快乐! 上传功能一直很正常,直到上传了个500多兆的文件 ...
- 关于width与padding
http://blog.csdn.net/yaoyuan_difang/article/details/24735529
- Python和SQL Server 2017的强大功能
Python和SQL Server 2017的强大功能 摘要: 源:https://www.red-gate.com/simple-talk/sql/sql-development/power-pyt ...
- SqlBulkCopy效率低下原因分析
看到标题 应该会奇怪 SqlBulkCopy 为什么会效率低下 场景:接手项目 数据库SQLSERVER2008R2, 目前有一张流水表单表数据超过4亿,表中建有索引,有其他模块对这个表进行查询操作 ...
- RoportNG报表显示中文乱码和TestNG显示中文乱码实力解决办法
最近在进军测试自动化框架学习阶段,但无意间总是会伴随小问题的困扰,比如中文乱码,而导致显示总是不舒服,个人觉得,就一定要解决,似乎有点点强迫症.所以遇到RoportNG报表显示中文乱码和TestNG显 ...
- Thrift总结(三)Thrift框架
1.数据类型 基本类型: bool:布尔值,true 或 false,对应 Java 的 boolean byte:8 位有符号整数,对应 Java 的 byte i16:16 位有符号整数,对应 J ...
- Java 7 JVM和垃圾收集
---恢复内容开始--- 写JAVA程序,一定要了解JVM(JAVA Virtual machine)一些基础知识和垃圾收集.如果对JVM已经很了解了,可以不用继续往下阅读了.本文只针对Java 7, ...
- [ACdream]女神教你字符串——导字符串
Problem Description 正如大家知道的,女神喜欢字符串,而在字符串中,女神最喜欢回文字符串,但是不是所有的字符串都是回文字符串,但是有一些字符串可以进行“求导”来变成回文字符串. 字符 ...
- servlet的运行工作
我是一个刚学几天的小白,写得不好,如果哪个地方有错误,欢迎你们指出. 在服务器端,我用的是Tomcat作为Servlet 容器,在容器中有一个Servlet接口,你编写一个servlet类放在Tomc ...
- Asp.net Api中使用OAuth2.0实现“客户端验证”
一.实现继承自OAuthAuthorizationServerProvider的类,实现以"客户端验证"方式传入的相关认证和access_token发放. public class ...