如何对适合其他值的二维数组进行排序?

问题描述:

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 
+0

尝试了详细的讲解,你想你的结果是和各个步骤需要以那里做什么。 –

+0

@ThorbjørnRavnAndersen所以阵列的左侧充满随机值,并进行排序的方法,他们得到这样排序的最高值是从阵列的底部。现在在数组的右边有1,2,3,4等等。这个具体的数字属于每一个随机值,比如基督徒应该永远是数字2或者亨利应该总是数字1.所以这些数值得到排序,但是在排序方法之后,我想确定哪个数据集的值最高?我如何排序随机值和具体数字保持其随机值? :)请帮助 – L2XU

+0

一些不相关的建议:如果可能,请尝试养成用英文编码的习惯。好的做法,行业标准,当你最终在这样的国际平台上提问时,它也会派上用场。 :) – domsson

如果我理解正确的话,你希望交换的对一个“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])

+0

是的,你太棒了!非常感谢你!我也不得不删除int temp = 0的定义;现在它工作。很好:) – L2XU

+0

不客气。滑稽你如何标示这是正确的,但不给予好评它是有用的,虽然:P – Imus

+0

的给予好评被记录下来,但我的名誉是15岁以下,因此不会显示出来:d – L2XU