だから私は現在、いくつかのオプションの部分がある大学向けの演習を行っています(クラスでこれをまだ行っていないため)。そのうちの1つは、配列の代わりにリストを使用することです(したがって、可変サイズになります)。ポイントでソートされたリストを印刷します(今すぐそれを取得します)
だから、私はこのように見える Player.java クラスを持っています。
public class Player {
String name;
String password;
int chips;
int points;
public Player(String n, String pw, int c, int p) {
name = n;
password = pw;
chips = c;
points = p;
}
public String getName() {
return name;
}
public void setName(String n) {
name = n;
}
public void setPW(String pw) {
password = pw;
}
public String getPW() {
return password;
}
public void setChips(int c) {
chips = c;
}
public int getChips() {
return chips;
}
public void setPoints(int p) {
points = p;
}
public int getPoints() {
return points;
}
}
非常に単純です。次に、これを使用してリストを作成しています(別のクラスで):
List<Player> lplayer = new ArrayList<Player>();
これでプレーヤーを追加します:
lplayer.add(new Player(n,pw,c,p))`
そして最後にこれで彼らの統計を読んでください:
public int search_Player (String n) {
String name;
int i = 0;
boolean found = false;
while ((i <= tp) && (!found)) {
name = lplayer.get(i).getName();
if (name.equals(n)) {
found = true;
}
i++;
}
return (found == true) ? i-1 : -1;
}
public Player show_Player (int i) {
return lplayer.get(i);
}
public void list_Players() {
Collections.sort(lplayer);
int i2;
if (tp > 0) { // variable which contains number of total players
for (int i = 0;i<tp;i++) {
i2 = i+1;
System.out.println ("\n"+i2+". "+lplayer.get(i).getName()+" [CHIPS: "+lplayer.get(i).getChips()+" - POINTS: "+lplayer.get(i).getPoints()+"]");
}
}
else {
System.out.println ("There are no players yet.");
}
}
つまり、基本的にすべてのコードです。ご覧のとおり、私はすでに list_Players 関数を持っていますが、追加された順序で出力するだけです。各プレイヤーが持っているポイント (基本的にはランキング) で並べ替えて印刷する方法が必要です。
ご覧のとおり、私は Java にかなり慣れていないので、非常に複雑な方法を考え出さないようにしてください。
私はすでにそれを検索して Collections.sort(list) のようなものを見つけましたが、それは私がここで必要としているものではないと思います。
ありがとうございました!