このような二分探索を書くのがなぜ間違っているのでしょうか?
<php function binarySearch($arr,$a){ $low = 0; $high = count($arr)-1; $mid = ceil(($low+$high)/2);while($low<=$high){ if($a==$arr[$mid]){ echo "查找的数的位置是第"."$mid"; } if($a>$arr[$mid]){ $high = count($arr)-1; $low = $mid+1; $mid = ceil(($low+$high)/2); } if ($a<$arr[$mid]) { $low = 0; $high = $mid-1; $mid = ceil(($low+$high)/2); } }}$arr1 = array(5,7,9,10,12,16,19);binarySearch($arr1,12);?>
ディスカッションに返信 (解決策)
function binarySearch($arr,$a){
$mid = ceil( ($low+$high)/2);
$n = 0;無限ループ
while($low<=$high && $n++
$high = カウント ($ Arr) - 1;
$ Low = $ MID -1; // ここで注意してください
$ MID = CEIL (($ Low+$ High)/2); {
$low = $mid
}
を押しますphpは実際にできる書かれてください
function binarySearch($arr,$a){ $low = 0; $high = count($arr)-1; $mid = ceil(($low+$high)/2); $num = count($arr); while($low<=$high && $num--){ if($a==$arr[$mid]){ echo "查找的数的位置是第"."$mid"; break; } list($low, $high) = $a > $arr[$mid] ? array($mid, $high) : array($low, $mid); $mid = ceil(($low+$high)/2); }}
この投稿は xuzuning によって最終編集されました: 2013-03-30 17:42:33
$high = count($ arr)-1
$mid = ceil(($low+$high)/2; );
$n = 0;無限ループを防ぐための対策…
ちょっとめまいがする $r=array(1,2,3,4) などの数字が4つある場合 のようです1. $mid を見つけるには、floor を使用してください。これは理解しています。
php によると、実際には次のように記述できます。PHP code?1234567891011121314function binarySearch($arr, $a) ){ $low = カウント($arr)-1; $mid = ceil(($low+$high)/2); &&……[/quote
モデレータにはまだ感謝しなければなりません、、、
rree

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック











多くの場合、キーワードと追跡パラメーターで散らかった長いURLは、訪問者を阻止できます。 URL短縮スクリプトはソリューションを提供し、ソーシャルメディアやその他のプラットフォームに最適な簡潔なリンクを作成します。 これらのスクリプトは、個々のWebサイトにとって価値があります

Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

これは、LaravelバックエンドとのReactアプリケーションの構築に関するシリーズの2番目と最終部分です。シリーズの最初の部分では、基本的な製品上場アプリケーションのためにLaravelを使用してRESTFUL APIを作成しました。このチュートリアルでは、開発者になります

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

2025 PHP Landscape Surveyは、現在のPHP開発動向を調査しています。 開発者や企業に洞察を提供することを目的とした、フレームワークの使用、展開方法、および課題を調査します。 この調査では、現代のPHP Versioの成長が予想されています

この記事では、Laravel Webフレームワークの通知システムを検討します。 Laravelの通知システムを使用すると、さまざまなチャネルでユーザーに通知を送信できます。今日は、通知ovを送信する方法について説明します
