美文网首页
2018-03-14

2018-03-14

作者: simple波 | 来源:发表于2018-03-14 13:15 被阅读0次

    /**

       * 冒泡排序

       * 思路:每次循环排列出一个最大的数

       */  

    public function mao_paoOp(){

          $data = array(5,2,6,4,3,1,9,8,4,5,14,25,41,12,52,32,42); 

          $total = count($data); 

          //循环控制需要冒的轮数 

          for($i=0; $i<$total ; $i++){ 

              //每轮 冒出的数 比较 

              for ($j=$i+1; $j<$total;$j++){ 

                  if($data[$i]>$data[$j]){ 

                      //接收的空变量 

                      $rem = $data[$i]; 

                      $data[$i] = $data[$j]; 

                      $data[$j] = $rem; 

                  } 

              } 

          }

    print_r($data);

      }

    /**

    * 选择排序

    * 思路:每一趟在n-i+1(i = 1,2,…,n-1)个记录中选择关键字最小的记录作为有序序列中第i个记录, 

     * 其中最简单的是简单选择排序,其过程如下:通过n-i次关键字间的比较,

     * 从n-i+1个记录中选择出关键字最小的记录,并各第i个记录交换之。

       */  

    public function select_mathOp(){  

    $data = array(5,2,6,4,3,1,9,8,4,5,14,25,41,12,52,32,42);  

    $total = count($data);  

    for ($i=0;$i<$total;$i++){  

    //假设最小值位置  

    $p = $i;  

    //当前需要比较的元数  $i的后面  

    for ($j=$i+1;$j<$total;$j++){  

    if($data[$p]>$data[$j]){  

    //发现有更小的  记录  

    $p = $j;  

                   }  

               }  

    //发现最小的和当前的位置不一样 对调  

    if($p !=$i){  

    $tem = $data[$p];  

    $data[$p] = $data[$i];  

    $data[$i] = $tem;  

               }  

           }  

    print_r($data);  

       }

    /**

     * 插入排序

     * 思路:通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,

     * 通常采用in-place排序(即只需用到O(1)的额外空间的排序),因而在从后向前扫描过程中,

     * 需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间

     */  

    public function insert_mathOp(){  

    $data = array(5,2,6,4,3,1,9,8,4,5,14,25,41,12,52,32,42);  

    $total = count($data);  

    for ($i=1;$i<$total;$i++){  

    $tmp = $data[$i];  

          for ($j=$i-1;$j>=0;$j--){  

    if($tmp<$data[$j]){  

    $data[$j+1] = $data[$j];  

    $data[$j] = $tmp;  

    }else{  

    break;  

                }  

            }  

        }  

    //$this->response($data,2000);  

    print_r($data); 

    /**

        * 快速排序

        * 思路:先对数组进行分割, 把大的元素数值放到一个临时数组里,

        * 把小的元素数值放到另一个临时数组里(这个分割的点可以是数组中的任意一个元素值,一般用第一个元素,即$array[0]),

        * 然后继续把这两个临时数组重复上面拆分,最后把小的数组元素和大的数组元素合并起来。这里用到了递归的思想。

        */  

    public function quick_sort_mathOp(){  

    $data = array(5,2,6,4,3,1,9,8,4,5,14,25,41,12,52,32,42);  

    $data_tmp = $this->quick_sort($data);  

    $this->response($data_tmp,2000);  

     } 

    /**

      * 使用递归方式

      * @param $data

      * @return array

      */  

    public function quick_sort($data){  

    $total = count($data);  

    //递归的时候 要防止死循环  

    if($total<=1){  

    return $data;  

         }  

    $base_num = $data[0];  

    $left_data   = array(); //小于  

    $right_data  = array();  //大于  

    for ($i=1;$i<$total;$i++){  

    if($base_num>$data[$i]){  

    $left_data[] = $data[$i];  

    }else{  

    $right_data[] = $data[$i];  

             }  

         }  

    $left_data = $this->quick_sort($left_data);  

    $right_data = $this->quick_sort($right_data);  

    $data_tmp = array_merge($left_data,array($base_num),$right_data);  

    return $data_tmp;  

     }  

    相关文章

      网友评论

          本文标题:2018-03-14

          本文链接:https://www.haomeiwen.com/subject/gglfqftx.html