php二分查找二种实现示例_PHP

Jun 01, 2016 am 11:55 AM
二分探索

php二分查找示例

二分查找常用写法有递归和非递归,在寻找中值的时候,可以用插值法代替求中值法。
当有序数组中的数据均匀递增时,采用插值方法可以将算法复杂度从中值法的lgN减小到lglgN

复制代码 代码如下:
/**
 * 二分查找递归解法
 * @param type $subject
 * @param type $start
 * @param type $end
 * @param type $key
 * @return boolean
 */
function binarySearch_r($subject, $start, $end, $key)
{

 if ( $start >= $end ) return FALSE;
 $mid = getMidKey($subject, $start, $end, $key);
 if ( $subject[$mid] == $key ) return $mid;
 if ( $key > $subject[$mid] ) {
  return binarySearch($subject, $mid, $end, $key);
 }
 if ( $key   return binarySearch($subject, $start, $mid, $key);
 }
}

/**
 * 二分查找的非递归算法
 * @param type $subject
 * @param type $n
 * @param type $key
 */
function binarySearch_nr($subject, $n, $key)
{
 $low = 0;
 $high = $n;
 while ( $low   $mid = getMidKey($subject, $low, $high, $key);
  if ( $subject[$mid] == $key ) return $mid;
  if ( $subject[$mid]    $low = $mid + 1;
  }
  if ( $subject[$mid] > $key ) {
   $high = $mid - 1;
  }
 }
}
function getMidKey($subject, $low, $high, $key)
{
 /**
  * 取中值算法1 取中值 不用 ($low+$high)/2的方式是因为 防止low和high较大时候,产生溢出....
  */
 //return round($low + ($high - $low) / 2);

 /**
  * 经过改进的插值算法求中值,当数值分布均匀情况下,再降低算法复杂度到lglgN
  * 取中值算法2
  */
 return round( (($key - $subject[$low]) / ($subject[$high] - $subject[$low])*($high-$low) ) );
}

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

C# を使用して二分探索アルゴリズムを作成する方法 C# を使用して二分探索アルゴリズムを作成する方法 Sep 19, 2023 pm 12:42 PM

C# を使用して二分探索アルゴリズムを作成する方法

マルチスレッド処理にpthreadを使用したC言語で書かれた二分探索プログラム マルチスレッド処理にpthreadを使用したC言語で書かれた二分探索プログラム Aug 26, 2023 pm 12:45 PM

マルチスレッド処理にpthreadを使用したC言語で書かれた二分探索プログラム

Javaを使用して二分探索アルゴリズムを実装する方法 Javaを使用して二分探索アルゴリズムを実装する方法 Sep 19, 2023 pm 12:57 PM

Javaを使用して二分探索アルゴリズムを実装する方法

Python を使用して二分探索アルゴリズムを実装するにはどうすればよいですか? Python を使用して二分探索アルゴリズムを実装するにはどうすればよいですか? Sep 20, 2023 pm 01:24 PM

Python を使用して二分探索アルゴリズムを実装するにはどうすればよいですか?

C言語の二分探索アルゴリズムを使用して配列内の最小要素を見つけるにはどうすればよいですか? C言語の二分探索アルゴリズムを使用して配列内の最小要素を見つけるにはどうすればよいですか? Aug 25, 2023 pm 08:37 PM

C言語の二分探索アルゴリズムを使用して配列内の最小要素を見つけるにはどうすればよいですか?

二分探索アルゴリズムを使用して数値の立方根を見つける Java プログラム 二分探索アルゴリズムを使用して数値の立方根を見つける Java プログラム Aug 28, 2023 pm 01:33 PM

二分探索アルゴリズムを使用して数値の立方根を見つける Java プログラム

C プログラムでは、浮動小数点演算を使用せずに二分探索アルゴリズムを使用して有理数を検索します。 C プログラムでは、浮動小数点演算を使用せずに二分探索アルゴリズムを使用して有理数を検索します。 Aug 27, 2023 pm 06:05 PM

C プログラムでは、浮動小数点演算を使用せずに二分探索アルゴリズムを使用して有理数を検索します。

PHP アルゴリズム分析: 二分探索アルゴリズムを使用して、順序付けされた配列内の要素をすばやく見つけるにはどうすればよいですか? PHP アルゴリズム分析: 二分探索アルゴリズムを使用して、順序付けされた配列内の要素をすばやく見つけるにはどうすればよいですか? Sep 19, 2023 pm 01:14 PM

PHP アルゴリズム分析: 二分探索アルゴリズムを使用して、順序付けされた配列内の要素をすばやく見つけるにはどうすればよいですか?

See all articles