Java代码实现
public static void shellSort(int[] arr) {
int len = arr.length;
//增量, 选择合适的增量有助于性能提升
int inc = 2;
// 步长
int step = len / inc;
for (; step > 0; step /= inc) {
//从第r个元素,逐个对其所在组进行直接插入 排序 操作
for (int r = step; r < len; r ++) {
// 左边要比较的值
int l = r - step;
int insertValue = arr[r];
for (; l >= 0 && insertValue < arr[l]; l -= step) {
arr[l + step] = arr[l];
}
arr[l + step] = insertValue;
}
}
}
GoLang 代码实现
func shellSort(arr []int) {
len := len(arr)
// 增量
inc := 2
// 步长
step := len / inc
for ; step > 0; step /= inc {
for r := step; r < len; r ++ {
// 最小下标为0
l := r - step
tmp := arr[r]
for ; l >= 0 && tmp < arr[l]; l -= step {
arr[l+step] = arr[l]
}
arr[l+step] = tmp
}
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 图形化排序算法比较:快速排序、插入排序、选择排序、冒泡排序
- 排序算法下——桶排序、计数排序和基数排序
- 算法之常见排序算法-冒泡排序、归并排序、快速排序
- 【JS面试向】选择排序、桶排序、冒泡排序和快速排序简介
- 计数排序vs基数排序vs桶排序
- 排序算法--冒泡排序
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
虚拟现实:最后的传播
聂有兵 / 中国发展出版社 / 2017-4-1 / 39.00
本书对“虚拟现实”这一诞生自70年代却在今天成为热门话题的概念进行了历史发展式的分析和回顾,认为虚拟现实是当今最重大的社会变革的技术因素之一,对虚拟现实在未来百年可能给人类社会的各个层面带来的影响进行说明,结合多个大众媒介的发展趋势,合理地推演未来虚拟现实在政治、经济、文化等领域的态势,并基于传播学理论框架提出了几个新的观点。对于普通读者,本书可以普及一般的虚拟现实知识;对于传媒行业,本书可以引导......一起来看看 《虚拟现实:最后的传播》 这本书的介绍吧!