PHP implements Bubble sorting and bidirectional bubble sorting algorithms

Source: Internet
Author: User

Bubble sort is a simple and stable sorting algorithm. Bubble Sorting Algorithm step: Compare adjacent elements. If the first element is larger than the second one, the two of them are exchanged. perform the same operation on each adjacent element, the final element is the largest. In addition to the obtained largest element, repeat the remaining elements in the previous step until no elements need to be compared. This sorting is complete. In the best case, the time complexity of the bubble algorithm is O (n). In the worst case, the time complexity is O (n2), and the average time complexity is O (n2 ).

PHP implements Bubble sorting and bidirectional bubble sorting algorithms
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149 <?php/** * Data Structure and algorithm (implemented in PHP)-bubble sort ). *
 * @ Author creative programming (topphp. org) * @ Copyright (c) 2013 creative programming (topphp. org) All Rights Reserved * @license http://www.opensource.org/licenses/mit-license.php MIT LICENSE * @version 1.0.0 - Build20130608 */class
BubbleSort {
  /**   * Bubble sorting.   *
   * @var integer   */  const
SORT_NORMAL = 1;   /**   * Bidirectional bubble sorting.   *
   * @var integer   */  const
SORT_DUPLEX = 2;   /**   * Array of data to be sorted.   *
   * @var array   */  private
$data;   /**   * The length of the data array.   *
   * @var integer   */  private
$size;   /**   * Whether the data array is sorted.   *
   * @var boolean   */  private
$done;   /**   * Constructor-Initialize data.   *
   * @ Param array $ array of data to be sorted.   */  public
function __construct(array
$data) {    $this->data =
$data;    $this->size =
count($this->data);    $this->done = FALSE;  }   /**   * Swap the positions of two elements in the data array.   *
   * @ Param integer $ X index of the element in the array.   * @ Param integer $ y index of the element in the array.   */  private
function swap($x,
$y) {    $temp
= $this->data[$x];    $this->data[$x] =
$this->data[$y];    $this->data[$y] =
$temp;     }   /**   * Bubble sorting.   */  private
function sort() {    $this->done = TRUE;     for
($i
= 1;
$i <
$this->size; ++$i) {      // Record the number of data exchanges.      $swap
= 0;       for
($j
=
$this->size - 1;
$j > $i
- 1; --$j) {        if
($this->data[$j] <
$this->data[$j
- 1]) {          $this->swap($j
- 1, $j);          ++$swap;        }      }       // If the number of data exchanges is 0, it indicates that the data array is ordered and does not have to be sorted.      if
(0 === $swap) {        break
;      }    }  }   /**   * Bidirectional bubble sorting.   */  private
function duplexSort() {    $this->done = TRUE;     for
($i
= 1;
$i <=
floor($this->size / 2); ++$i) {      // Record the number of data exchanges.      $swap
= 0;       for
($j
=
$this->size - 1,
$k = $i
- 1;        $j
> $i
- 1 &&
$k <
$this->size - 1; --$j, ++$k) {        if
($this->data[$j] <
$this->data[$j
- 1]) {          $this->swap($j
- 1, $j);          ++$swap;        }         if
($this->data[$k] >
$this->data[$k
+ 1]) {          $this->swap($k,
$k + 1);          ++$swap;        }      }       // If the number of data exchanges is 0, it indicates that the data array is ordered and does not have to be sorted.      if
(0 === $swap) {        break;      }    }  }   /**   * Obtain the sorted data array.   *
   * @ Param integer $ sort Sorting Algorithm: sort_normal indicates Bubble Sorting; sort_duplex indicates bidirectional bubble sorting.   * @ Return array returns the sorted data array.   */  public
function getResult($sort
= self::SORT_NORMAL) {    // If the data has been sorted, no sort is required and the sorted data array is directly returned.    if
($this->done) {      return
$this->data;    }     switch
($sort) {      case
self::SORT_DUPLEX:        $this->duplexSort();        break;       case
self::SORT_NORMAL:      default:        $this->sort();        break;    }     return
$this->data;  }}?>
Sample Code
1234 <?php$bubble
=
new BubbleSort(array(35, 75, 92, 41, 27, 58));echo
'<pre>'
, print_r($bubble->getResult(BubbleSort::SORT_DUPLEX), TRUE),
'</pre>';?>

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.