快速排序-js

基本思想:分治法,先在数组中将第一个数设置为key,然后用两个指针(low,high)从两边遍历数组,要求low小于high,low指向值大于等于key则暂停,high指向值小于key则暂停,当两个指针都停下时,如果low指向值小于high指向值,则它们指向的数换位,然后继续遍历,否则比较key与high指向的值,当key小于high指向的值并且high大于key所在的下标的值,那么指针继续左移,直到不满足条件为止,不满足key小于high指向的值并且high大于key所在的下标的值的时候,如果key大于high指向的值,那么它们换位,返回此时high,否则返回key的下标,执行完一次上述过程,数组会被二分,并且左边部分都比key小,右边部分都比key大,这样对两边再进行上述操作,直到排序完成。

function quickSort(arr, first, last){
	if (first < last) {
		var pivot = getPivot(arr, first, last);
		quickSort(arr, first, pivot-1);
		quickSort(arr, pivot+1, last);
	}
}

function getPivot(arr, first, last){
	let point = arr[first];
	let low = first + 1;
	let high = last;
	while(high > low){
		while(high >= low && arr[low] <= point){
			low++;
		}
		while(high >= low && arr[high] > point){
			high--;
		}
		if(low < high){
			let temp = arr[high];
			arr[high] = arr[low];
			arr[low] = temp;
		}
	}
	while(point <= arr[high] && high > first){
		high--;
	}
	if (point > arr[high]) {
		arr[first] = arr[high];
		arr[high] = point;
		return high;
	}else{
		return first;
	}
}

时间复杂度:O(nlogn);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
单片微型计算机(MCU)经过多年的发展,在性能上有很大的进步,在型号上发展到上千种类,已经广泛应用于人类社会生活的各个领域。单片机课程已经成为高校计算机、自动化、测控以及电子信息工程等专业的重要课程。该课程是一门理论性和实践性都很强的课程,在实际教学中,应将理论教学和实验教学紧密结合。学生在掌握理论知识之余,必须通过编写程序、设计硬件电路、仿真、调试这一系列的实验过程,才能更好地掌握单片机的结构原理和应用技能。随着单片机及其接口技术的飞速发展,目前市场上供应的编程仿真实验资源并不能完全满足高校单片机课程教与学的需求,构建低成本、技术先进、源码公开的单片机编程仿真实验系统,对我国单片机课程的教学和单片机领域人才的培养具有重要的现实意义。 本论文结合目前教学中对单片机编程仿真实验系统的实际需求,采用模块化结构设计思想,精心设计和开发了单片机编程仿真实验系统。该单片机编程仿真实验系统由PC机端单片机编程控制软件和单片机编程仿真实验板两部分组成。PC机端的单片机编程控制软件可以自动检测到连接到单片机编程仿真实验板上的单片机,控制单片机编程器擦除、写入、读出、校验目标单片机ROM中的程序,以十六进制文件(.HEX文件)格式显示在控制界面内;单片机仿真实验系统能够把写入单片机的程序实时地运行,并呈现实际运行效果。单片机编程控制软件和单片机仿真实验板组成一个完整的单片机编程仿真实验系统。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值