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

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

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

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

Processing

Processingは、オープンソースプロジェクトによるCGのためのプログラミング言語です。Javaをベースにしており、グラフィック機能に特化しています。イメージの生成やアニメーションなど、視覚的なフィードバックを簡単に得ることが可能です。

Q&A

解決済

1回答

1908閲覧

数字並べ替えのソートのプログラムについて

likuson

総合スコア34

Java

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

Processing

Processingは、オープンソースプロジェクトによるCGのためのプログラミング言語です。Javaをベースにしており、グラフィック機能に特化しています。イメージの生成やアニメーションなど、視覚的なフィードバックを簡単に得ることが可能です。

0グッド

1クリップ

投稿2019/10/08 17:53

前提・実現したいこと

processingで数字をランダムに10個生成し、小さい順に並べ替えるソートを作っています。
ソートの順番は次のような手順で並べ替えます。
1.配列の要素を順方向へ順番に見ていく。
2.順序が逆になっている要素を見つけたらその要素を掴む。
3.掴んだ要素を一つ手前の要素と交換する。
「交換した後も順序が逆だったらさらに手前にずらす」
という操作を繰り返します。
4.ずらし終わったら、その位置から再び順方向へ要素を見て行く。
5.配列の最後の要素まで到達したらソート完了。
プログラムを書いたのですが、うまく並び替えることができませんでした。

発生している問題・エラーメッセージ

エラーメッセージはありません。

該当のソースコード

processing

1int D[]; 2int N=10; 3 4void setup(){ 5 D=new int [N]; 6 for(int i=0;i<N;i++){ D[i]=(int)random(100); } 7 noLoop(); 8} 9 10void draw() 11{ 12println("----- before -----"); 13println(D); 14 15for(int c=0;c<N-1;c++){ 16 for(int j=N=0;j<N-1;j++){ 17 if(D[j]>D[j+1]){ 18 int box=D[j]; 19 D[j]=D[j+1]; 20 D[j+1]=box; 21 22 23 } 24 } 25 26 27println("----- after -----"); 28println(D); 29} 30}

試したこと

for文の継続条件式をいじった。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

SHOMI

2019/10/08 20:19

間違っている箇所についてはすでに回答がついているので、別の点について。 定数を宣言する場合は型の前にfinalをつけます。 final int N=10; としておけば今回の原因であったN=0は定数を変更しようとしているためエラーとなります。 https://processing.org/reference/final.html
likuson

2019/10/09 01:22

なるほど。final関数は初めて知りました。ありがとうございます。
guest

回答1

0

ベストアンサー

バブルソートのアルゴリズムですね(定数倍高速化の余地はありますが)。

diff

1- for(int j=N=0;j<N-1;j++){ 2+ for(int j=0;j<N-1;j++){

この修正で正しくソートされるかと思われます。

投稿2019/10/08 18:05

set0gut1

総合スコア2413

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

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

likuson

2019/10/09 01:21

ありがとうございます。うまくいきました。
set0gut1

2019/10/09 21:42

ベストアンサーありがとうございます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問