Java 实现二分(折半)插入排序

Java 实现二分(折半)插入排序

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

全栈程序员社区此处内容已经被作者隐藏,请输入验证码查看内容
验证码:
请关注本站微信公众号,回复“验证码”,获取验证码。在微信里搜索“全栈程序员社区”或者“www_javaforall_cn”或者微信扫描右侧二维码都可以关注本站微信公众号。

设有一个序列a[0],a[1]…a[n];当中a[i-1]前是已经有序的,当插入时a[i]时,利用二分法搜索a[i]插入的位置

效率:O(N^2),对于初始基本有序的序列,效率上不如直接插入排序;对于随机无序的序列,效率比直接插入排序要高

/* * 二分(折半)插入排序 * 设有一个序列a[0],a[1]...a[n];当中a[i-1]前是已经有序的,当插入时a[i]时,利用二分法搜索a[i]插入的位置 */public class BinaryInsertSort {	public static void main(String[] args) {		int len = 10;		int[] ary = new int[len];		Random random = new Random();		for (int j = 0; j < len; j++) {			ary[j] = random.nextInt(1000);		}		binaryInsert(ary);		/*		 * 复杂度分析: 最佳情况,即都已经排好序,则无需右移,此时时间复杂度为:O(n lg n) 最差情况,所有逆序,此时复杂度为O(n^2)		 *  无法将最差情况的复杂度提升到O(n|logn)。		 */		// 打印数组		printArray(ary);	}	/**	 * 插入排序	 * @param ary	 */	private static void binaryInsert(int[] ary) {		int setValueCount = 0;		// 从数组第二个元素開始排序,由于第一个元素本身肯定是已经排好序的		for (int j = 1; j < ary.length; j++) {// 复杂度 n			// 保存当前值			int key = ary[j];			// ∆ 利用二分查找定位插入位置//			int index = binarySearchAsc(ary, ary[j], 0, j - 1);// 复杂度:O(logn)//			int index = binarySearchDesc(ary, ary[j], 0, j - 1);// 复杂度:O(logn)			int index = binarySearchDesc2(ary, ary[j], 0, j - 1);// 复杂度:O(logn)			printArray(ary);			System.out.println("第" + j +"个索引上的元素要插入的位置是:" + index);			// 将目标插入位置,同一时候右移目标位置右边的元素			for (int i = j; i > index; i--) {// 复杂度,最差情况:(n-1)+(n-2)+...+n/2=O(n^2)				ary[i] = ary[i - 1]; //i-1 <==> index				setValueCount++;			}			ary[index] = key;			setValueCount++;		}		System.out.println("\n 设值次数(setValueCount)=====> " + setValueCount);	}	/**	 * 二分查找 升序 递归	 * 	 * @param ary	 *            给定已排序的待查数组	 * @param target	 *            查找目标	 * @param from	 *            当前查找的范围起点	 * @param to	 *            当前查找的返回终点	 * @return 返回目标在数组中,按顺序应在的位置	 */	private static int binarySearchAsc(int[] ary, int target, int from, int to) {		int range = to - from;		// 假设范围大于0,即存在两个以上的元素,则继续拆分		if (range > 0) {			// 选定中间位			int mid = (to + from) / 2;			// 假设临界位不满足,则继续二分查找			if (ary[mid] > target) {				/*				 * mid > target, 升序规则,target较小,应交换位置 前置, 即target定位在mid位置上,				 * 依据 查找思想, 从from到 mid-1觉得有序, 所以to=mid-1				 */				return binarySearchAsc(ary, target, from, mid - 1);			} else {				/*				 * mid < target, 升序规则,target较大,不交换位置,查找比較的起始位置应为mid+1				 */				return binarySearchAsc(ary, target, mid + 1, to);			}		} else {			if (ary[from] > target) {//如 5,4, 要插入的是4				return from;			} else {				return from + 1;			}		}	}	/**	 * 二分查找 降序, 递归	 */	private static int binarySearchDesc(int[] ary, int target, int from, int to) {		int range = to - from;		if (range > 0) {			int mid = (from + to) >>> 1;			if (ary[mid] > target) {				return binarySearchDesc(ary, target, mid + 1, to);			} else {				return binarySearchDesc(ary, target, from, mid - 1);			}		} else {			if (ary[from] > target) {//如 5,4, 要插入的是4				return from + 1;			} else {				return from;			}		}	}		/**	 * 二分查找 降序, 非递归	 */	private static int binarySearchDesc2(int[] ary, int target, int from, int to) {//		while(from < to) {		for (; from < to; ) {			int mid = (from + to) >>> 1;			if (ary[mid] > target) {				from = mid + 1;			} else {				to  = mid -1;			}		}		//from <==> to;		if (ary[from] > target) {//如 5,4, 要插入的是4			return from + 1;		} else {			return from;		}	}	private static void printArray(int[] ary) {		for (int i : ary) {			System.out.print(i + " ");		}	}}

打印

918 562 442 531 210 216 931 706 333 132 第1个索引上的元素要插入的位置是:1918 562 442 531 210 216 931 706 333 132 第2个索引上的元素要插入的位置是:2918 562 442 531 210 216 931 706 333 132 第3个索引上的元素要插入的位置是:2918 562 531 442 210 216 931 706 333 132 第4个索引上的元素要插入的位置是:4918 562 531 442 210 216 931 706 333 132 第5个索引上的元素要插入的位置是:4918 562 531 442 216 210 931 706 333 132 第6个索引上的元素要插入的位置是:0931 918 562 531 442 216 210 706 333 132 第7个索引上的元素要插入的位置是:2931 918 706 562 531 442 216 210 333 132 第8个索引上的元素要插入的位置是:6931 918 706 562 531 442 333 216 210 132 第9个索引上的元素要插入的位置是:9 设值次数(setValueCount)=====> 24931 918 706 562 531 442 333 216 210 132 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117937.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • k8s pod控制器_k8s控制器

    k8s pod控制器_k8s控制器k8sPod控制器的介绍ReplicaSet(RS)Deployment(Deploy)扩缩容镜像更新版本回退金丝雀发布Horizontal Pod Autoscaler(HPA)DaemonSet(DS)JobCronJob(CJ)StatefulSet(有状态)StatefulSet的金丝雀发布k8s的Pod控制器详解主要介绍各种Pod控制器的详细使用。Pod控制器的介绍在kubernetes中,按照Pod的创建方式可以将其分为两类:自主式Pod:kubernetes直接创建出来的Pod,这

    2022年8月11日
    9
  • springboot整合tkmybatis以及使用

    springboot整合tkmybatis以及使用经常用 mybatis 的的都知道 使用 mybatisorm 框架存在一个非常不友善的问题就是 就是每操作一个单表就需要自己手写一个 xml 文件 虽然说可以用工具生成 xml 和实体类可以解决这个问题 但是二次开发的时候对某个表字段进行修改的时候 生成 xml 文件就不现实啦 最近发现 tkmybatis 就非常好的解决了这个问题 在这里和大家分享一下 框架配置这里需要引用到的包 mybat

    2025年6月15日
    1
  • bat 剪切文件_bat延时命令

    bat 剪切文件_bat延时命令扩展名是bat(在nt/2000/xp/2003下也可以是cmd)的文件就是批处理文件。首先批处理文件是一个文本文件,这个文件的每一行都是一条DOS命令(大部分时候就好象我们在DOS提示符下执行的命令行一样),你可以使用DOS下的Edit或者Windows的记事本(notepad)等任何文本文件编辑工具创建和修改批处理文件。其次,批处理文件是一种简单的程序,可以通过条件语句(if)和流程控制语句(…

    2022年9月24日
    5
  • 集合类型python_python需要学哪些

    集合类型python_python需要学哪些集合集合的特点:是一种可迭代的、无序的、不能包含重复元素的数据结构去重b=[10,5,6,1,9,1]c=set(b)print(c)>>>{1,5

    2022年8月6日
    3
  • BP神经网络基础算法

    BP神经网络基础算法

    2021年6月5日
    133
  • k8s kubedns_kubernetes使用

    k8s kubedns_kubernetes使用K8s应用部署方式的演变kubernetes简介kubernetes组件kubernetes组件调用关系的应用示例kubernetes概念应用部署方式的演变应用部署方式的演变• 在部署应用程序的方式上,主要经历了三个时代:传统部署:• 互联网早期,会直接将应用部署在物理机上。• 优点:简单,不需要其他的技术参与。• 缺点:不能为应用程序定义资源的使用边界,很难合理的分配计算机资源,而且程序之间容易产生影响。虚拟化部署:• 可以在一台物理机上运行多个虚拟机,每个虚拟机都是独立的一个环境。

    2022年8月11日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号