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

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

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

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

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

Q&A

解決済

1回答

2127閲覧

phpにてクイックソートが実現できません。。

smith_30

総合スコア26

PHP

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

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

0グッド

0クリップ

投稿2016/09/08 11:51

下記コードを元にしてクイックソートが実現できなくて困っています。
問題としてはQuickSort関数内で随時整列させていく配列データが保持していけないことです。

QuickSort関数が整列結果を返す形でもいいので
何かアドバイスいただけないでしょうか。

再帰処理でどういう順序で動いているのかは理解しています。

php

1<?php 2 3/** @var array 整列対象の配列 **/ 4$target = [5, 4, 7, 6, 8, 3, 1, 2, 9]; 5 6QuickSort($target, 0, count($target)-1); 7 8var_dump($target); //正しい整列結果が出る 9 10/* 11 * @param array 12 * @param ini 13 * @param int 14 * 15 */ 16function QuickSort(array $target, int $left, int $right) 17{ 18 19 $i = $left + 1; 20 $k = $right; 21 22 /* 23 * 基準値を値にしてデータを大小に分ける 24 */ 25 while ($i < $k) { 26 27 /** 28 * $iを使って、基準値より大きい要素を探す 29 */ 30 while ($target[$i] < $target[$left] && $i < $right) { 31 ++$i; 32 } 33 34 /** 35 * $kを使って、基準値より小さい要素を探す 36 */ 37 while ($target[$k] >= $target[$left] && $k > $left) { 38 --$k; 39 } 40 41 /** 42 * 大きいデータと小さいデータを変換する 43 */ 44 if ($i < $k) { 45 $swap = $target[$i]; 46 $target[$i] = $target[$k]; 47 $target[$k] = $swap; 48 } 49 50 } 51 52 if ($target[$left] > $target[$k]) { 53 $swap = $target[$left]; 54 $target[$left] = $target[$k]; 55 $target[$k] = $swap; 56 } 57 58 if ($left < $k-1) { 59 QuickSort($target, $left, $k-1); 60 } 61 62 if ($k+1 < $right) { 63 QuickSort($target, $k+1, $right); 64 } 65 66} 67

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

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

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

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

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

guest

回答1

0

ベストアンサー

配列の参照渡しが出来ていなくて、関数呼び出し時に複製されちゃってるから?とか
コードをじっくり読んだわけではありませんが、もしかすると以下のようにしたら動いたりしませんか?

php

1function QuickSort(array &$target, int $left, int $right)

投稿2016/09/08 12:42

編集2016/09/08 12:45
hirohiro

総合スコア2068

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

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

smith_30

2016/09/08 15:16

うわぁ、一発で行けました。 大変感謝です。笑
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問