冒泡排序,OSX,跑得同一个数据集,10000 个随机 int 型数,kotlin 版的代码在 jvm 上跑用了 160ms,而 c 版的代码则跑了 300 毫秒。我写的 c 是不是有啥问题?
fun bubbleSort(arr: IntArray?) {
if (arr == null || arr.isEmpty()) return
var temp: Int
for (i in 0 until arr.size) {
for (j in arr.size - 1 downTo i + 1) {
if (arr[j] < arr[j - 1]) {
temp = arr[j]
arr[j] = arr[j-1]
arr[j-1] = temp
}
}
}
}
void bubbleSort(int a[]) {
int i,j,tmp;
for (i = 0; i < SIZE; i++) {
for (j = SIZE-1; j > i; j--) {
if (a[j] < a[j-1]) {
tmp = a[j];
a[j] = a[j-1];
a[j-1] = tmp;
}
}
}
}
其实我原本只是想看看 jvm 处理这类问题的效率比 c 慢多少,没想到是这样的结果,求大神告诉我是为啥
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.