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

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

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

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

ソート

複数のデータを、順序性に従って並べ替えること。 データ処理を行う際に頻繁に用いられ、多くのアルゴリズムが存在します。速度、容量、複雑さなどに違いがあり、高速性に特化したものにクイックソートがあります。

Q&A

解決済

1回答

7783閲覧

クイックソートで無限ループしてしまう。

退会済みユーザー

退会済みユーザー

総合スコア0

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

ソート

複数のデータを、順序性に従って並べ替えること。 データ処理を行う際に頻繁に用いられ、多くのアルゴリズムが存在します。速度、容量、複雑さなどに違いがあり、高速性に特化したものにクイックソートがあります。

0グッド

0クリップ

投稿2016/01/04 09:24

クイックソートのアルゴリズムを自分で書こうとしたのですが、上手くいきません。具体的に言うと、配列の数字がすべて違っていれば問題ないのですが、基準値となる値が重複している場合、無限ループになってしまうのです。

java

1public class Quick { 2 3 public static void main(String[] args) { 4 int[] array = {4,8,6,1,2,9,0,3,5,7}; 5 int datum = array[0];//先頭の値を基準値とする 6 7 System.out.println("配列arrayの中身は"); 8 System.out.println(java.util.Arrays.toString(array) + "です。"); 9 System.out.println("クイックソートで一回だけソートします。"); 10 System.out.println(); 11 12 for(int left = 0,right = array.length-1;left < right;){ 13 /*配列の左側から走査。 14 *基準値、または基準値以上の値を見つけるまで続ける。 15 */ 16 while(array[left] < datum){ 17 left++; 18 } 19 /*配列の右側から走査。 20 *基準値、または基準値以下の値を見つけるまで続ける。 21 */ 22 while(array[right] > datum){ 23 right--; 24 } 25 //left,rightが入れ替わっていなかったら値を交換する。 26 if(left < right){ 27 int tmp = array[left]; 28 array[left] = array[right]; 29 array[right] = tmp; 30 } 31 } 32 33 System.out.println("配列arrayは"); 34 System.out.println(java.util.Arrays.toString(array)); 35 System.out.println("になりました。"); 36 37 } 38 39} 40
//実行結果 配列arrayの中身は [4, 8, 6, 1, 2, 9, 0, 3, 5, 7]です。 クイックソートで一回だけソートします。 配列arrayは [3, 0, 2, 1, 4, 9, 6, 8, 5, 7] になりました。 //基準値より左側は基準値以下の値、右側は基準値以上の値になる。

この配列だとうまくいくのですが、例えば
int[] array = {4,8,6,1,2,9,0,3,5,4}
だった場合、最初と最後の4の交換を無限に行ってしまうのです。

if(array[left] == array[right]) で処理しようと思ったのですが、どういう風に処理すればいいのかわかりませんでした。どこを直したらいいのでしょうか。

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

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

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

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

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

guest

回答1

0

ベストアンサー

C++

1/*配列の左側から走査。 2 *基準値、または基準値以上の値を見つけるまで続ける。 3 */ 4while(array[left] < datum){ 5 left++; 6}

C++

1/*配列の右側から走査。 2 *基準値、または基準値以下の値を見つけるまで続ける。 3 */ 4while(array[right] > datum){ 5 right--; 6}

のどっちかが<=か>=じゃないとうまく動かない

投稿2016/01/04 09:30

_nyannyan_

総合スコア124

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

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

退会済みユーザー

退会済みユーザー

2016/01/04 09:59

これはすでに試していて、確かにこうすれば無限ループは回避できるんですが、正しくクイックソートできないんですよ。 [4, 4, 3, 1, 2, 0, 9, 6, 5, 8] か [3, 0, 2, 1, 6, 9, 8, 4, 5, 4] になる…ってあれ? よく見ると下の配列は1と6の間で基準値以下と基準値以上に分かれていますね。ちょっと勘違いしていました。ありがとうございます。
退会済みユーザー

退会済みユーザー

2016/01/04 12:08

勘違いしていた部分がわかった。分割点は基準値があるところじゃなくて、ソートが終わった後のleftの位置なのか。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問