需要帮助了解如何使用java

时间:2015-07-31 02:27:54

标签: java arrays file sorting multidimensional-array

我正在尝试构建一个从.txt文件中读取信息的程序,该文件包含20个人。每个人有四个领域,他们所属的球队,他们的击球率和本垒打总数。我需要将每个人添加到他们的团队(每个团队4个玩家),总计团队本垒打总数,并按顺序排列5个团队。 我能够正确地将文本读取到由每个人组成的单个数组中,但我无法弄清楚如何使用这些数据来创建2D数组。我会使用2D数组,将玩家放在正确的团队中,并添加他们的本垒打总数。我想对每个团队和每个人的本垒打总数从最大到最小排序。我已经尽力找到答案,并在其他帖子和网站上学习,但我只是难以理解创建2D数组的概念以及如何对它们进行排序。

更新说明: 这就是单个数组的信息:

 [Team][Name][avg][Home Runs]

然后我只想对[Home Runs]列进行排序,从最大到最小,但不知道如何只访问该部分数组。

2D数组应如下所示:

  [Team] [Total Team Home Runs]

再一次,从最大到最小排序。

.txt文件的示例如下所示:

 Team: Name:         Avg:HR:

 MILRyan Braun       .31015
 STLMatt Adams       .28718
 PITSterling Marte   .26420
 CINJoey Votto       .30224
 CUBAnthony Rizzo    .27422
 PITAndrew McCutchen .29522
 MILAdam Lind        .28013

以下类读入.txt文件并将其放入数组中。

  public class ReadTxt {

static String[] teamm = new String[20];
static String[] name = new String[20];
static int[] avg = new int[20];
static double[] homeRuns = new double[20];

static String teams;
static int i;

public void Players(String[] teamm, String[] name, int[] avg, double[] homeRuns){
String[] team = new String[20];


File txtFile = new File("C:\\Users\\Users Name\\Desktop\\homerun.txt");

try{

    Scanner txtScan = new Scanner(txtFile);
    while(txtScan.hasNext()){

        for(i = 0; i < 20; i++){
            teams = txtScan.nextLine();
            team[i] = teams;
        }
    }

}
catch(FileNotFoundException e){
    System.out.println("File not found" + txtFile);
}

for (i = 0; i < team.length; i++){

    System.out.println(team[i]);
    }
}
}

下一课是我尝试排序:

public class Sort {

static String[] teamm = new String[20];
static String[] name = new String[20];
static int[] avg = new int[20];
static double[] homeRuns = new double[20];
private int index = 0;
private int US = 0;
static double[] homeRunArray;


public void Players(String[] teamm, String[] name, int[] avg, double[] homeRuns){
homeRunArray[index] = ReadTxt.homeRuns[index];
index++;;
US++;
}

public void selectionSort(){
    double temp;
    int min;

    for(int i = 0; i < US-2; i++){
        min = i;
        for(int j=i+1; j<= US-1; j++){
            if(min !=i){
                temp = homeRunArray[i];
                homeRunArray[i] = homeRunArray[min];
                homeRunArray[min] = temp;
            }
        }

    }
}

public void printArray(double[] homeRuns){
    for(int i = 0; i < 20; i++){

    System.out.print(homeRunArray[i]);
    }
        System.out.print("\n");
    }
}

1 个答案:

答案 0 :(得分:0)

我不明白你的问题,但我认为你有点陷入2D阵列问题......

我建议您创建一个类并实现Comparable(或使用Comparator)。像下面的代码,甚至更好的东西,成为一个真正的Player类。这更容易理解。

public class Sorter {
    public static void main(String[] args) {
        try {
            Scanner scanner = new Scanner(new File("team"));
            List<SortableLine> lines = new ArrayList<SortableLine>();
            while(scanner.hasNext()) {
                lines.add(new SortableLine(scanner.nextLine()));
            }
            Collections.sort(lines);
            for(SortableLine line : lines) {
                System.out.println(line.line);
            }
        } catch(FileNotFoundException e) {
            System.err.println("File not found");
        }
    }

    private static class SortableLine implements Comparable<SortableLine> {
        private String sortCol;
        private String line;

        private SortableLine(String line) {
            this.line = line;
            this.sortCol = line.substring(24, 26);
        }

        public int compareTo(SortableLine other) {
            return sortCol.compareTo(other.sortCol);
        }
    }
}