改进ban冒泡排序】的更多相关文章

设置一标志性变量pos,用于记录每趟排序中最后一次进行交换的位置.由于pos位置之后的记录均已交换到位,故在进行下一趟排序时只要扫描到pos位置即可. //改进后算法如下: function bubbleSort2(arr) { console.time('改进后冒泡排序耗时'); var i = arr.length-1; //初始时,最后位置保持不变 while ( i> 0) { var pos= 0; //每趟开始时,无记录交换 for (var j= 0; j< i; j++){ i…
改进的冒泡排序 一.算法描述 基于原冒泡排序 每次选取第一个元素作为主元往后进行比较,若遇到比它小的则放到它左边(即进行交换),若遇到比它大的则选取大的作为主元进行后续比较,每趟选取了无序列中最大元素放置无序列最后位,当一趟比较没有发生交换则为有序序列,即像吐泡泡一样第一次把最大的数吐到最末位,第二趟把倒数第二大的数吐到倒数第二位..... 到last,同样当某趟排序不发生交换时完成排序 二.算法分析 原每趟排序的范围固定为0到n,0到n-1,0到n-2......到last,且每次的last是…
改进冒泡思路 如果在某次的排序中没有出现交换的情况,那么说明在无序的元素现在已经是有序了,就可以直接返回了. 改进冒泡实现 Function.prototype.method = function(name, func){ this.prototype[name] = func; return this; }; Array.method('rBubbleSort', function(){ var len = this.length, i, j, tmp, exchange; for(i=0;…
冒泡排序算法 冒泡排序算法 改进一 冒泡排序算法 改进二 冒泡排序算法 改进三 冒泡排序算法 基本思想: 在要排序的一组数中,对当前还未排好序的范围内的全部数据,自上而下对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的数往上冒.即依次比较相邻的两个数,若发现它们的排序与排序要求相反时,就将它们互. 实例: 待排序数组 int a[] = {49,38,65,97,76,13,27,32}; 共 N=8 个数据,需要 N-1=7 趟排序,第 i 趟排序共比较 N-i 次 每趟排序都会找出…
基本思想: 在要排序的一组数中,对当前还未排好序的范围内的全部数,自上而下对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒. 即:每当两相邻的数比较后发现它们的排序与排序要求相反时,就将它们互换. 冒泡排序的示例: 算法的实现: void bubbleSort(int a[], int n){ for(int i =0 ; i< n-1; ++i) { for(int j = 0; j < n-i-1; ++j) { if(a[j] > a[j+1]) { int tmp…
代码中在第一层循环中增加一个bool值,是为了防止在排序完成后还继续无谓的比较,最多会有(n-1)*(n-2)/2次循环. #include<iostream> using namespace std; void bumbleSort(int a[],int l) { ;i<l;i++) { bool b = true; ;j<l-i-;j++) { ]) { if(b) b = false; int temp = a[j]; a[j] = a[j+]; a[j+] = temp;…
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>冒泡排序(bublesort)</title> <script>// console.log(new Date().getTime()); console.time('冒泡排序耗时'); var arr=[3,44,38,5,47,15,36,26,…
冒泡排序(Bubble sort) 两两比较相邻记录的关键字,如果反序则交换,直到没有反序记录为止. 1.算法描述: 比较相邻的元素.如果第一个比第二个大,就交换它们两个: 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对,这样在最后的元素应该会是最大的数: 针对所有的元素重复以上的步骤,除了最后一个: 重复步骤1~3,直到排序完成. 2.算法属性: 时间复杂度:O(n^2) 空间复杂度:O(1) 稳定性:稳定(下图Stable*表示是否稳定) O(1) :额外的空间  (best c…
基本思想: 在要排序的一组数中,对当前还未排好序的范围内的全部数,自上而下对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒.即:每当两相邻的数比较后发现它们的排序与排序要求相反时,就将它们互换. 冒泡排序的示例: 算法实现 /** * * @author zhangtao */ public class BubbleSort { public static void main(String[] args) { int arr[]={3,1,5,7,2,4,9,6,45,0,-1}…
冒泡排序的Javascript实现 首先定义一个取值范围在(0~100000)之间的随机值的长度为10万的数组, function bubbleSort(arr) { console.time('冒泡排序耗时'); var len = arr.length,temp; for(var i=0;i<len;i++){ for(j=0;j<len-i-1;j++){ if(arr[j]>arr[j+1]){ temp = arr[j+1]; arr[j+1] = arr[j]; arr[j]…