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

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

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

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

Q&A

解決済

4回答

2549閲覧

[java]配列を昇順、降順にソートする方法

newyee

総合スコア213

Java

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

0グッド

1クリップ

投稿2018/06/16 09:38

現在、プログラミングの勉強をしており、配列の要素を昇順、降順に並び替えたプログラムを作成したいと思っているのですが、なかなかうまくいきません...
以下は僕が作成したコードなのですが、降順を指定しても、全ての要素が一番大きい要素に書き換わってしまいます。
どなたか、教えてくださる方いましたら、よろしくお願いします。

java

1public class lesson5 { 2 3 public static void main(String[] args) { 4 5 int[] array1 = {96,45,31,29,84,77}; 6 7 OrderInfo order = new OrderInfo(); 8 9 order.display(array1,false); 10 11 order.arraySort(array1,false); 12 13 order.display(array1,true); 14 15 } 16}

java

1public class OrderInfo{ 2 3 public void display(int[] array,boolean isSorted) { 4 5 if(isSorted == false) { 6 7 System.out.println("***並び換え前***"); 8 9 } else { 10 11 System.out.println("***並び換え後***"); 12 } 13 14 15 for(int i = 0; i< array.length; i++) { 16 17 System.out.println(array[i]); 18 19 } 20 } 21 22 public void arraySort(int[] array, boolean orderType) { 23 24 for(int i = 0; i < array.length; i++) { 25 26 for(int j = 0; j < array.length; j++) { 27 28 if(orderType == false) { 29 30 if(array[i] < array[j]){ 31 32 change(array,i,j); 33 34 } 35 36 } else { 37 38 if(array[i] > array[j]) { 39 40 change(array,i,j); 41 } 42 } 43 44 } 45 46 47 } 48 49 50 51 } 52 53 54 public void change(int[] array, int i, int j){ 55 56 array[i] = array[j]; 57 58 } 59 60 61}

実行結果:

並び換え前
96
45
31
29
84
77
並び換え後
96
96
96
96
96
96

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

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

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

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

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

guest

回答4

0

for(int j = 0; j < array.length; j++) {
つぎに array の内容を表示させるようにして、意図した動作とどう違っていあるかがわかると思います。
まずは array1 = {1,2,3};にして、実行してみるとよいです。
その次に [2,1] や {3,2,1] などでも実行してみてください。

投稿2018/06/16 13:34

katoy

総合スコア22324

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

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

newyee

2018/06/17 08:15

ご回答ありがとうございます。僕、実際に表示させてみるということすら、頭になかったので、分からなくなった際は変数の中身を表示するなどして、確かめていきたいと思います!
guest

0

public static void main (String[] args) throws java.lang.Exception{ List<Integer> arr = Arrays.asList(96,45,31,29,84,77); arr.stream().sorted((a,b)->a-b).forEach(v->System.out.println(v));//昇順 arr.stream().sorted((a,b)->b-a).forEach(v->System.out.println(v));//降順 }

投稿2018/06/16 10:09

tkturbo

総合スコア5572

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

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

newyee

2018/06/16 10:25

ご回答ありがとうございます。まだ、勉強途中なのですが、ご回答下さったのはjavaのapiを利用したものでしょうか...? 今回はapiを利用せず、一度自分で処理を考え作ってみようと思ったんですよね...
guest

0

ベストアンサー

要素を『入れ替える』必要があるのですよね。

Java

1public void change(int[] array, int i, int j){ 2 int tmp = array[i]; 3 array[i] = array[j]; 4 array[j] = tmp; 5}

投稿2018/06/16 09:39

LouiS0616

総合スコア35660

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

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

newyee

2018/06/16 10:21

ご回答いただきありがとうございます。 どうしても分からない部分があるのですが、     「if(orderType == false) { if(array[i] < array[j]){ change(array,i,j); }」←ここの部分で、最初のarray[0]番目の「96」の比較が、一回目の繰り返し処理で終わり、2回目の繰り替えし処理に移行しているにも関わらず、実行結果では、全ての要素に対して、96が代入されているのですが、これがどうしても分からないんですよね...
newyee

2018/06/16 10:30

すみません。追記です。ご回答下さったコードで試してみたのですが、やはりすべての要素に対し、「96」が代入されてしまいます...
LouiS0616

2018/06/16 10:35 編集

> どうしても分からない部分がある 可視化して観察してみるといいかもしれないですね。https://goo.gl/XFKNwi リンク先を開いて少し待つと図が表示されますので、『forward』ボタンを押して処理を進めつつ観察してみると勉強になるかと。 (処理を簡単にするため、コードを少し書き直しています)
LouiS0616

2018/06/16 10:34

> ご回答下さったコードで試してみたのですが、やはりすべての要素に対し、「96」が代入されてしまいます... 私の手元ではソート出来ましたので、コード以外の箇所に問題がありそうです。 いまいちど正しく実行しているかご確認ください。
newyee

2018/06/16 11:35

ご丁寧に教えて頂きありがとうございます。教えて下さってリンクで試してみたのですが、理由が分かりました。内側のfor文で「j」の値が2回目の繰り返し時に「0」に戻っていたからなんですね... 何度もお聞きして申し訳ないのですが、教えて頂いたリンクのソフトは、例えば他のコードで処理手順を確認したい際にも、使うことは可能でしょうか? 分かりました。コード以外の部分を見直して、試してみたいと思います!
newyee

2018/06/16 12:00

ありがとうございます。 活用させて頂こうと思います。
guest

0

答えからいいますと

java

1for(int i=0; i < array.length-1; i++) { 2 for(int j=0; j < array.length-i-1; j++) { 3 if(array[j] > array[j+1]) { //←ここの不等号で昇順か降順か決まる 4 int asc = array[j]; 5 array[j] = array[j+1]; 6 array[j+1] = asc; 7 } 8 } 9}

こんな感じになります。

投稿2018/06/16 10:43

編集2018/06/16 10:57
michael-ilcsy

総合スコア180

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

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

newyee

2018/06/16 12:02

ご回答頂きありがとうございます。 参考にさせて頂き、試してみたいと思います。
newyee

2018/06/17 08:08

教えて頂いたやり方で、試させていただきました! 入れ替える際の処理は、変数「i」を使うものだと思っていたので、変数「j」だけで入れ替えるというのは、まったく考えになかっので、大変勉強になりました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問