排序 - 草稿

JS代码位置

最好写在body标签闭合之前,这样浏览器会在加载脚本之前,解析和显示HTML,有利于提升页面的性能

快排

var quickSort = function(arr){
    //检查数组的元素个数,如果小于等于1,就返回
    var len = arr.length;
    if(len <= 1){
      return arr
    }
    //接着,选择"基准"(pivot),并将其与原数组分离,再定义两个空数组,用来存放一左一右的两个子集。
    var pivotIndex = Math.floor(arr.length / 2);
  var pivot = arr.splice(pivotIndex, 1)[0];
    var left  = [];
        right = [];
    // 然后,开始遍历数组,小于"基准"的元素放入左边的子集,大于基准的元素放入右边的子集。
    arr.forEach((item)=>{
      if(item < pivot){
        left.push(item)
      }else{
        right.push(item)
      }
    })
    //合并左右数组
    return quickSort(left).concat([pivot],quickSort(right))
}
var arr = [3,77,66,55]
console.log(quickSort(arr))//[3,55,66,77]

贪心算法

 function MinCoins(coins){
  var coins = coins;
  this.change = function(num){
    var res   = [],
        total = 0;

    for(var i = coins.length-1;i>=0;i--){
      var coin = coins[i]
      while(total+ coin <= num){
        res.push(coin)
        total += coin
      }
    }
    return res;
  }
 }
 var minCoins = new MinCoins([1,5,10,25])
 var a = minCoins.change(36)
  console.log(a)

冒泡 排序


  function bubbleSort(arr){
    var len = arr.length;
    for(var i=0;i<len;i++){
      for(var j=0;j<len-1-i;j++){
        if(arr[j]>arr[j+1]){
          var temp = arr[j]
          arr[j] = arr[j+1]
          arr[j+1]=temp
        }
      }
    }
    return arr
  }

选择排序

function selectSort(arr){
  var len=arr.length;
  var minIndex,temp;
  console.time('选择排序耗时');
  for(i=0;i<len-1;i++){
      minIndex=i;
      for(j=i+1;j<len;j++){
          if(arr[j]<arr[minIndex]){
              minIndex=j;
          }
      }
  temp=arr[i];
  arr[i]=arr[minIndex];
  arr[minIndex]=temp;
  }
  console.timeEnd('选择排序耗时');
  return arr;
}

插入排序

function insert(arr){
  var len = arr.length,
      temp,
      j;
  for(var i=1;i<len;i++){
    temp = arr[i]
    j = i
    while(arr[j-1]>temp&&j>0){
      arr[j] = arr[j-1]
      j--;
    }
    arr[j] = temp
  }
  return arr
}

归并排序

function merge(leftArr, rightArr){  
  var result = [];  
  while (leftArr.length > 0 && rightArr.length > 0){  
    if (leftArr[0] < rightArr[0])  
      result.push(leftArr.shift()); //把最小的最先取出,放到结果集中   
    else   
      result.push(rightArr.shift());  
  }   
  return result.concat(leftArr).concat(rightArr);  //剩下的就是合并,这样就排好序了  
}  

function mergeSort(array){  
  if (array.length == 1) return array;  
  var middle = Math.floor(array.length / 2);       //求出中点  
  var left = array.slice(0, middle);               //分割数组  
  var right = array.slice(middle);  
  return merge(mergeSort(left), mergeSort(right)); //递归合并与排序  
}  
二分搜索
function binarySearch(arr,target){
  arr.sort((a-b)=>{a-b})
  var low = 0,
      heigh =arr.length-1,
      mid;
  while(low<=heigh){
    mid = Math.floor(low+heigh/2),
    if(target<arr[mid]){
      heigh = mid - 1
    }else if(target>height){
      low = mid + 1
    }else{
      return mid
    }
  }
  return -1;
}
DFS递归
function DFS(node){
  var res = []
  while(node!=null){
    res.push(node);
    children = node.children;
    for(var i=0;i<children.length;i++){
      node = children[i]
      DFS(node)
    }
  }
  return res;
}

BFS

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,076评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,658评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,732评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,493评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,591评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,598评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,601评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,348评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,797评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,114评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,278评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,953评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,585评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,202评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,180评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,139评论 2 352

推荐阅读更多精彩内容

  • 因为之前就复习完数据结构了,所以为了保持记忆,整理了一份复习纲要,复习的时候可以看着纲要想具体内容。 树 树的基本...
    牛富贵儿阅读 6,861评论 3 10
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 5,178评论 0 52
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 3,729评论 0 15
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 将一个记录插入到已排序好...
    依依玖玥阅读 1,250评论 0 2
  • 1.主食:可以选择大米、玉米、小麦、高粱、燕麦等偏碱性类食物;2.蔬菜类:选择冬瓜、黄瓜、南瓜、丝瓜和卷心菜等不舍...
    a2b8b6facbec阅读 518评论 0 0