Java初心者です。
Javaで「n番目に大きい値を探索」するプログラムを組みたいのですが、お力を貸してください!
配列データ(10)には各要素に1~10の値が入っています。
ただし配列データをランダムで数値を入れた場合でも動くこと。
ランダムで決めたn番目の値を探索するプログラムです。
----
int[] data = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
//配列データの順番はランダムに並び替わります
int n = random.nextInt(data.length) + 1;
for(int range = 0; range < n; range ++) {
//n番目の要素が見つからなかった場合
if(n > data.length) {
System.out.print(n + "番目に大きい要素は見つかりませんでした。");
break;
}
/* 範囲の先頭から最後まで処理を繰り返し、範囲内の最小値が格納
* されている要素を決定する
*/
for(int seach = range + 1; seach < data.length; seach ++) {
//基準値より探索値が小さかった場合
if(data[range] <= data[seach]) {
int swa = data[range];
data[range] = data[seach];
data[seach] = swa;
}
}
//n番目の要素が見つかった場合
if(n -1 == range) {
System.out.print(n + "番目に大きい要素は" + data[range] + "です。");
break;
}
}
----
と言う感じで一度組んでみたのですが、
配列に格納されている値を変更しないようにと言われました。
まず一番大きな値を探し、その値より小さい値を順に探索していけばいいのだと思うのですが、いまいち分かりません。
誰か教えてください。よろしくお願いします。
No.7ベストアンサー
- 回答日時:
難しく考えすぎじゃないですか? 質問者さんが仰るとおり「まず一番大きな値を探し、その値より小さい値を順に探索していけばいい」のだと私も思います(^^;。
「配列の中から最大値を探索する」線形探索問題の次の課題だと思いますが、単純な応用問題ですよ。
「配列の中から最大値を探索する」場合、仮の最大値と配列の要素を比較しますが、そこに、「一番大きな値より小さい」という条件を追加するだけです。
「配列の中からn番目に大きな値を探索する」ときは、この判定条件が「n-1番目に大きな値より小さい」と変化するだけです。
上限値 = 0
for(n回繰り返し)
仮の最大値 = 0
for(配列要素数繰り返し)
if(配列の要素 > 仮の最大値)
if(上限値 == 0)
仮の最大値 = 配列の要素
else if(配列の要素 < 上限値)
仮の最大値 = 配列の要素
上限値 = 仮の最大値
こんな感じ(^^;)
No.5
- 回答日時:
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
public class Nbanme {
public static void main(String[] args) {
List<Integer> list = Arrays.asList(new Integer[]{1, 2, 3, 4, 5, 6, 7, 8, 9, 10});
Collections.shuffle(list);
System.out.printf("現在の配列内容[%d",list.get(0));
for ( int i = 1 ; i < list.size() ; i++ ){
System.out.printf(",%d",list.get(i));
}
System.out.println("]");
int num = (int)(Math.random()*10+1);
System.out.printf("%d番目に大きい要素は",num );
System.out.printf("%dです。",list.get(list.indexOf(new Integer(11 - num))));
}
}
ただし、学校の課題とかの場合この回答では○もらえないかと。
何をやっているかどうかは考えてみてください。
この回答への補足
昇順に並んでいる配列から、nを引くとn番目が出ると言う解釈で大丈夫でしょうか?
しかし、配列の内容を変更しない(入れ替えをしないと言うことだと思うのですが)
とのことで、ランダムに並んでしまうとこれは通用しないと思うのですが…。
No.3
- 回答日時:
public static void main( String args[] ) {
int[] data = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
int n = random.nextInt(data.length) + 1;
System.out.print(n + "番目に大きい要素は" + (11 - n) + "です。");
}
この回答への補足
>System.out.print(n + "番目に大きい要素は" + (11 - n) + "です。");
配列の中身は数も順序もランダムになるので、は使えないんです。
No.2
- 回答日時:
多分NGかと思いますが。
import java.util.Arrays;
import java.util.List;
public class Nbanme {
public static void main(String[] args) {
List<Integer> list = Arrays.asList(new Integer[]{1, 2, 3, 4, 5, 6, 7, 8, 9, 10});
int num = (int)(Math.random()*10);
System.out.printf("number is:%d",num );
System.out.printf(" / index is:%d",list.indexOf(new Integer(num)));
}
}
こんな方法もある、という一例です。
No.1
- 回答日時:
data = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
rank = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
配列データの順序を指し示す配列を設定してみては、いかがでしょう。
まず、data の先頭要素が、最大と仮定し、・・・
rank = {1, 0, 0, 0, 0, 0, 0, 0, 0, 0};
この先頭要素と、それ以外の 各data 要素とを比較する。
仮に、比較した data要素の方が大きければ、最大要素を設定しなおす。
rank = {0, 1, 0, 0, 0, 0, 0, 0, 0, 0};
これを、data の最終要素までの比較を繰り返し、その時点の最大要素が
結果となります。
rank = {0, 0, 0, 0, 0, 0, 0, 0, 0, 1};
続いて、2番目に大きな要素を、上記と同様に仮設定を行い、rank 配列が
0 である data 要素との比較を繰り返す。
rank = {2, 0, 0, 0, 0, 0, 0, 0, 0, 1};
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・「みんな教えて! 選手権!!」開催のお知らせ
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~1/20】 追い込まれた犯人が咄嗟に言った一言とは?
- ・洋服何着持ってますか?
- ・みんなの【マイ・ベスト積読2024】を教えてください。
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・【選手権お題その3】この画像で一言【大喜利】
- ・【お題】逆襲の桃太郎
- ・自分独自の健康法はある?
- ・最強の防寒、あったか術を教えてください!
- ・【大喜利】【投稿~1/9】 忍者がやってるYouTubeが炎上してしまった理由
- ・歳とったな〜〜と思ったことは?
- ・ちょっと先の未来クイズ第6問
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・【選手権お題その2】この漫画の2コマ目を考えてください
- ・【選手権お題その1】これってもしかして自分だけかもしれないな…と思うあるあるを教えてください
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Javaで文字と数字が混ざったも...
-
セッションを使ったint型の値の...
-
java 大文字と小文字を入れ替える
-
『args[]』とは?
-
javaで大容量テキストファイル...
-
NaN(Not a Number)を配列に入れ...
-
String型をbyte型へ
-
プログラミングの問題です。大...
-
VBAでアルファベットと記号を昇...
-
VB.net 引数で配列変数を渡す際...
-
ループ処理の際、最後だけ","を...
-
C言語のポインターに関する警告
-
指定した座標の色を得るためには
-
Javaでタイマーの使い方
-
InputStream.read()でタイムア...
-
javaで質問です。 文字列2023/2...
-
空欄のテキストフィールドの判...
-
C#でキーイベントが発生しない...
-
C言語32bitから64bitの移行につ...
-
javaの初歩的な質問です。
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
[Ljava.lang.Stringってなんですか
-
ArrayListからBean配列に値をセ...
-
Javaで文字と数字が混ざったも...
-
配列の中に複数存在する数がい...
-
C#で動的配列Listの中身をListB...
-
この警告はどうすれば?
-
【C#】ハッシュテーブル(連想...
-
javamailで複数人にメールを送...
-
java StringとString[]の違い
-
JavaのBase64デコードで正しく...
-
main(String[] args) の args...
-
javaで大容量テキストファイル...
-
Java配列の問題を教えてくださ...
-
jspでの二次元配列
-
sqlparamaterでIN句を使いたい。
-
java
-
javaについて
-
C言語でunsigned char配列を連...
-
Javaで文字を漢字であるか否か...
-
【Ajax通信&Java】配列の受け取...
おすすめ情報