質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

1回答

666閲覧

PHPのusortの挙動

obst_001

総合スコア15

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2018/05/23 14:20

前提・実現したいこと

usortの挙動を教えてください。

PHP5技術者認定試験の問題集のソースで、
以下の結果は「5123456789」と表示されるとなっています。

PHP

1function funv($x,$y){ 2 if($x == 5) { 3 return -1; 4 } else if($y == 5) { 5 return 1; 6 } else { 7 return $x -$y; 8 } 9} 10$a = array(8,2,3,6,7,9,1,5,4); 11usort($a,'func'); 12foreach($a as $v){ 13 echo$v 14}

マニュアルには以下とありますが、最初の引数と二番目の引数というのは何を比較しているのでしょうか。

最初の引数と二番目の引数の比較結果を返します。 最初の引数のほうが二番目の引数より大きい場合は正の数を、 二番目の引数と等しい場合はゼロを、 そして二番目の引数より小さい場合は負の数を返す必要があります。

実際のusortの挙動は以下の認識ですが、結果が「5123456789」となりません。
何が違うのでしょうか。

①まず最初に第一引数は8、第二引数は2となる
②$x-$yの正の数が返ってくるので、第二引数が大きいとみなされる
(もうこの時点8 < 2という判定なので誤りですよね?)
③usortは昇順のため「82」と設定される。
④次の第一引数は??、第二引数は3
・・・の流れではないのでしょうか・・・?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

PHPのソート関数は内部でクイックソートが使われているため、先頭から順番に2個が引数になるわけではありません。クイックソートのアルゴリズムについては検索してください。

マニュアルの説明文は、最初の引き数は $x, 二番目の引数は $y という認識で合ってます。
$x が 8, $y が 2 の場合は、$x -$y は 6 になり、最初の引数のほうが二番目の引数より大きい場合は正の数を を満たしてますよね? 8 のほうが 2 より大きいので 6 を返してるわけです。

あと、配列の中に 5 が 1 個しかないのに 5123456789 になるわけがないのでタイプミスだと思いますが、
コピペして2箇所エラーを修正した後 PHP Sandbox で実行してみたら、ちゃんと 512346789 になりましたよ。

投稿2018/05/23 14:49

yhg

総合スコア2161

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問