时代Java,与您同行!
关注微信公众号,关注前沿技术,微信搜索:nowjava或时代Java,也可点击这里扫码关注
时代Java
首页
集册
文章
实例
项目
快讯
时代+
手册
下载
Jar查找
登录
注册
Java 折半插入排序算法实例
Java 折半插入排序算法实例
欢马劈雪
工程师 (已认证)
原创分享签约作者
发表于
实例源码
订阅
956
查看 / 运行 实例源码
折半插入排序是直接插入排序与折半查找二者的结合,仍然是将待排序元素插入到前面的有序序列,插入方式也是由后往前插,只不过直接插入排序是边比较边移位。而折半插入排序则是先通过折半查找找到位置后再一并移位,最终将待排序元素赋值到空出位置。
实例源码:
源代码:
执行
执行中...
/** * 折半插入排序 的实现 稳定算法 * nowjava.com */ public class InsertSort { public static void main(String[] args) { // TODO Auto-generated method stub int a[] = { 3, 1, 5, 7, 2, 4, 9, 6 }; new InsertSort().doInsertSort(a); } /** * 折半插入排序算法的实现 */ private void doInsertSort(int[] a) { // TODO Auto-generated method stub System.out.println("—————折半插入排序算法—————"); int n = a.length; int i, j; for (i = 1; i < n; i++) { /** * temp为本次循环待插入有序列表中的数 - nowjava.com */ int temp = a[i]; int low = 0; int high = i - 1; /** * 寻找temp插入有序列表的正确位置,使用二分查找法 */ while (low <= high) { /** * 有序数组的中间坐标,此时用于二分查找,减少查找次数 */ int mid = (low + high) / 2; /** * 若有序数组的中间元素大于待排序元素,则有序序列向中间元素之前搜索,否则向后搜索 */ if (a[mid] > temp) { high = mid - 1; } else { low = mid + 1; } } for (j = i - 1; j >= low; j--) { /** * 元素后移,为插入temp做准备 */ a[j + 1] = a[j]; } /** * 插入temp */ a[low] = temp; /** * 打印每次循环的结果 */ print(a, n, i); } /** * 打印排序结果 */ printResult(a, n); } /** * 打印排序的最终结果 * * @param a * @param n */ private void printResult(int[] a, int n) { System.out.print("最终排序结果:"); for (int j = 0; j < n; j++) { System.out.print(" " + a[j]); } System.out.println(); } /** * 打印排序的每次循环的结果 * * @param a /**代码未完, 请加载全部代码(NowJava.com).**/
编辑/阅读全部代码
执行结果:
—————折半插入排序算法—————
第1次: 1 3 5 7 2 4 9 6
第2次: 1 3 5 7 2 4 9 6
第3次: 1 3 5 7 2 4 9 6
第4次: 1 2 3 5 7 4 9 6
第5次: 1 2 3 4 5 7 9 6
第6次: 1 2 3 4 5 7 9 6
第7次: 1 2 3 4 5 6 7 9
最终排序结果: 1 2 3 4 5 6 7 9
本文系作者在时代Java发表,未经许可,不得转载。如有侵权,请联系nowjava@qq.com删除。
编辑于
2020-02-21 20:24:47
2020-02-21 20:24:47
Java
折半
插入
排序
算法
实例
分享
分享文章到朋友圈
分享文章到 QQ
分享文章到微博
复制文章链接到剪贴板
扫描二维码
关注时代Java
实例源码
实例源码
订阅
订阅专栏
Java 判断文件是否为文本文件及获取文件编码格式的方法实例
bootstrap 实例演示下拉菜单(Dropdown)插件用法。
HashSet、LinkedHashSet、TreeSet类存储元素的自动排序规则实例测试
html css 对于 body和h1设置的实例源码
Java 获取在线网页的源代码
Java HashSet添加、迭代输出字符串的完整示例代码
Java 随机整数数组
html css 设置背景图片定位并且不平铺
扫描二维码
关注时代Java
返回顶部