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

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

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

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

Q&A

解決済

1回答

2004閲覧

java  じゃんけんゲーム 順位付け

kisaragizinzin7

総合スコア90

Java

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

0グッド

0クリップ

投稿2015/08/20 01:12

編集2015/08/20 01:18

すみませんが、前回と同じような質問になっています。

じゃんけんゲームを作っています。
3人でじゃんけんをして勝った人から1位から3位までを出して、それを2回戦行うというものを作り、 結果がこのように出たとします。

プレイヤー1の各順位の回数は1位0回, 2位0回, 3位2回
プレイヤー2の各順位の回数は1位1回, 2位1回, 3位0回
プレイヤー3の各順位の回数は1位1回, 2位1回, 3位0回

これを1位が多い人順に総合順位を決めたいです。
1位が同じ回数なら2位の回数で多い方を上位にします。
1位2位3位の回数がすべて同じなら同位にします。
同位が存在する場合、例えば1位が2人いるなら3人目は3位とします。

結果としては
1位プレイヤー2
1位プレイヤー3
3位プレイヤー1
このようにしたいです。

前回教えていただいた点数に変換してから順位付けをする方法でもやってみようと思うのですが、今回はComparatorでやっています。

コード public class PlayerOfComp implements Comparator<Player>{ public int compare(Player p1, Player p2) { int compare_rank = 0; for(int i = 0; i < player; i++){ compare_rank = p2.getRankarrange()[i] - p1.getRankarrange()[i]; } return compare_rank; } }

playerはプレイヤー人数3人
getRankarrangeはPlayerクラスにある各順位に何回なったか記録してある配列
private int rankarrange[] = new int[player];

public int[] getRankarrange(){
return rankarrange;
}

これでやってみたのですが、これだと3位の回数だけを比較して並べることになっているみたいで、
プレイヤー1
プレイヤー2
プレイヤー3
の順番で出力されてしまいます。
Comparatorを使ってすべての条件を満たすにはどう変更すればいいのか教えていただきたいです。
よろしくお願いいたします。

イメージとしては
・1位の回数を比較して同じ回数のプレイヤーがいれば、そのプレイヤーだけ取り出して2位の回数を比較。
2位も同じならこれを再度繰り返す。
・1位の回数を比較して回数がすべて違うならそのまま並べる
と考えています。
もしこの動作がComparatorではできないのであれば、ほかの方法を教えていただくとありがたいです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

比較する際,1位の回数に差があった時点で順位の優劣が決まるはずです.
このコードではforループを抜けないと値を返さないので,必ず3位の比較の値になってしまいます.
なので,forループの中で上位から回数を比較して,差が生じた時点で値を返す仕組みにしなければいけません.

あと前回の回答でまだComparatorの役目がわかっていないようですが,
配列の並び替えの際に使う天秤のようなものです.
詳しくはソートアルゴリズムを調べて貰いたいのですが,簡単に説明します.
ご質問のような「1位を比較して,同じものだけ2位以下を比較する」といった方法ではなく,
単純にComparatorを使ってPlayer同士を比較して,どちらがより上位かを判定しているに過ぎません.
そしてより上位と判定されたものを入れ替えなどにより配列の上位側に置いているだけのことなのです.
それを繰り返して,最終的に配列の中身が上位から順に並ぶようにしているのです.

表示時に同立を同じ順位で表示したいのなら,表示の段階で勝ち数比較して同立かを判定すれば済みます.
同じComparatorを使って0を返すなら,という条件にすれば楽かもしれません.

投稿2015/08/20 01:31

編集2015/08/20 02:08
swordone

総合スコア20649

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

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

kisaragizinzin7

2015/08/20 02:25

解説ありがとうございます^^ そういうことなんですね! Comparatorやっと理解できた気がします。 指摘していただいて問題も解決しました! public class PlayerOfComp implements Comparator<Player>{ public int compare(Player p1, Player p2) { int compare_rank = 0; for(int i = 0; i < Judge.player; i++){ compare_rank = p2.getRankarrange()[i] - p1.getRankarrange()[i]; if(compare_rank != 0){ break; } } return compare_rank; } } ありがとうございました。 同立判定も頑張ってみます!
swordone

2015/08/20 02:54

個人的には配列そのまま返すメソッドではなく,欲しい順位の数値を渡して その順位の回数を返すメソッドにしたほうがいいと思います. 配列をそのまま返してしまうとそれ経由で配列の中身を変更できてしまうので
kisaragizinzin7

2015/08/20 03:54

配列そのまま返すメソッドではなく,欲しい順位の数値を渡して その順位の回数を返すメソッドにしたほうがいい というのはどういうことでしょうか? return compare_rank;が配列ということですか?
swordone

2015/08/20 03:56

PlayerクラスのgetRankarrange()の方です.
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問