如何对适合其他值的二维数组进行排序?
问题描述:
public class Spieler
{
public Magier Henri = new Magier ("Magier Henri");
public Krieger Christian = new Krieger ("Krieger Christian");
public Supporter Judith = new Supporter ("Suppporter Judith");
public Schuetze Lukas = new Schuetze ("Schuetze Lukas");
public Magier Nick = new Magier ("Magier Nick");
public Krieger Anna = new Krieger ("Krieger Anna");
public Supporter Neele = new Supporter ("Suppporter Neele");
public Schuetze Christoph = new Schuetze ("Schuetze Christoph");
public int i;
public int besten5;
public int bestPlayerEU;
public int[][] kandidat = new int[8][2];
int t;
public void fuelleArray()
{
kandidat[0][0] = Henri.getGesamtPunkte();
kandidat[0][1] = 1;
kandidat[1][0] = Christian.getGesamtPunkte();
kandidat[1][1] = 2;
kandidat[2][0] = Judith.getGesamtPunkte();
kandidat[2][1] = 3;
kandidat[3][0] = Lukas.getGesamtPunkte();
kandidat[3][1] = 4;
kandidat[4][0] = Nick.getGesamtPunkte();
kandidat[4][1] = 5;
kandidat[5][0] = Anna.getGesamtPunkte();
kandidat[5][1] = 6;
kandidat[6][0] = Neele.getGesamtPunkte();
kandidat[6][1] = 7;
kandidat[7][0] = Christoph.getGesamtPunkte();
kandidat[7][1] = 8;
}
public int[][] sort()
{
fuelleArray();
int temp = 0;
for (int i = 0; i < kandidat.length; i++)
{
for(int j = 1; j < kandidat.length-i; j++)
{
if(kandidat[j][t] < kandidat[j-1][t])
{
temp = kandidat [j-1][t];
kandidat[j-1][t] = kandidat [j][t];
kandidat[j][t] = temp;
}
}
}
return kandidat;
}
}
所以在这里我得到我的数组的左侧排序的随机值,但我也希望二维数组右侧的值移动适合的字符。所以,我想的是,kandidat
“亨利”依然是价值1
,“基督徒” = 2
,“朱迪思” = 3
,“卢卡斯” = 4
等。有人可以解释或编写代码,使阵列右侧的数字适合字符/ kandidat
?如何对适合其他值的二维数组进行排序?
所以当阵列看起来像这样的开头:
0 1
0 26 1
1 45 2
2 37 3
3 33 4
4 27 5
5 29 6
6 41 7
7 49 8
它应该是这样的结尾:
0 1
0 26 1
1 27 5
2 29 6
3 33 4
4 37 3
5 41 7
6 45 2
7 49 8
答
如果我理解正确的话,你希望交换的对一个“kandidate”+号码将这些对保持在一起。你有没有尝试过这样的事情:
int[] temp = kandidat [j-1];
kandidat[j-1] = kandidat [j];
kandidat[j] = temp;
这个交换对(kanditate[j][0], kandidate[j][1])
与一对(kanditate[j-1][0], kandidate[j-1][1])
。
尝试了详细的讲解,你想你的结果是和各个步骤需要以那里做什么。 –
@ThorbjørnRavnAndersen所以阵列的左侧充满随机值,并进行排序的方法,他们得到这样排序的最高值是从阵列的底部。现在在数组的右边有1,2,3,4等等。这个具体的数字属于每一个随机值,比如基督徒应该永远是数字2或者亨利应该总是数字1.所以这些数值得到排序,但是在排序方法之后,我想确定哪个数据集的值最高?我如何排序随机值和具体数字保持其随机值? :)请帮助 – L2XU
一些不相关的建议:如果可能,请尝试养成用英文编码的习惯。好的做法,行业标准,当你最终在这样的国际平台上提问时,它也会派上用场。 :) – domsson