码迷,mamicode.com
首页 > 其他好文 > 详细

Partition算法及Partition算法用于快速排序

时间:2014-07-30 20:08:04      阅读:418      评论:0      收藏:0      [点我收藏+]

标签:style   http   color   java   io   for   art   cti   

JavaScript简单方便,所以用JavaScript实现,可以在Chrome控制台下观察运行结果。主要实现Partition算法,比如输入为 
  var array = [4, 2, 1, 3, 6, 8, 9, 7, 5]; 
  partition(array, 0, 8); 
那么按照array[0]即4进行划分,结果为 [3, 2, 1, 4, 6, 8, 9, 7, 5] 
?1. [代码][JavaScript]代码     

// 先来看Partition算法,Partition算法是快速排序的基础
<script type="text/javascript">
    // 划分算法
   function partition(array, p, r) {
      if(p < 0 || r < 0 || p >= r || r > array.length-1)
        return;
       
      var i = p;
      var pivot = array[i];
      for(var j = p+1; j <= r; j++) {
         if(array[j] < pivot) {
            i++;
            var temp = array[j];
            array[j] = array[i];
            array[i] = temp;
         }
      }
       
      // 交换array[i]和array[p]
      var temp = array[p];
      array[p] = array[i];
      array[i] = temp;
       
      return i;
  }
   
  var array = [4, 2, 1, 3, 6, 8, 9, 7, 5];
  partition(array, 0, 8);
  console.log(array);
</script>
2. [代码][JavaScript]代码   
// 基于上面的Partition算法,获得下面的快速排序算法
<script type="text/javascript">矢量素材
    // 划分算法http://www.huiyi8.com/shiliang/?
   function partition(array, p, r) {
      if(p < 0 || r < 0 ||  p >= r || r > array.length-1)
        return;
       
      var i = p;
      var pivot = array[i];
      for(var j = p+1; j <= r; j++) {
         if(array[j] < pivot) {
            i++;
            var temp = array[j];
            array[j] = array[i];
            array[i] = temp;
         }
      }
       
      // 交换array[i]和array[p]
      var temp = array[p];
      array[p] = array[i];
      array[i] = temp;
       
      return i;
  }
   
  function quickSort(array, p, q) {
     if(p > q || p < 0 || q < 0 || q > array.length-1)
        return;
      
     if(p==q)   // 递归终止条件
        return;
      
     var mid = partition(array, p, q);
     quickSort(array, p, mid-1);
     quickSort(array, mid+1, q); 
  }
   
  var array = [4, 2, 1, 3, 6, 8, 9, 7, 5];
  quickSort(array, 0, 8);
   
  console.dir(array);
</script>
?

Partition算法及Partition算法用于快速排序,布布扣,bubuko.com

Partition算法及Partition算法用于快速排序

标签:style   http   color   java   io   for   art   cti   

原文地址:http://www.cnblogs.com/xkzy/p/3878513.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!