3

我在 Java 中为一个读取文件、处理数据并将其打印出来的项目创建了一个二维数组。我遇到的唯一问题是尝试按字母顺序对二维数组进行排序。

这是文件输入的示例:

2011 Regular Season
Boston 162 5710 875 1600 352 35 203
NY_Yankees 162 5518 867 1452 267 33 222
Texas 162 5659 855 1599 310 32 210
Detroit 162 5563 787 1540 297 34 169
St.Louis 162 5532 762 1513 308 22 162
Toronto 162 5559 743 1384 285 34 186
Cincinnati 162 5612 735 1438 264 19 183
Colorado 162 5544 735 1429 274 40 163
Arizona 162 5421 731 1357 293 37 172
Kansas_City 162 5672 730 1560 325 41 129

这是输出的示例:

2011 Regular Season
====================
Boston:     .280 .461
NY_Yankees: .263 .444
Texas:      .283 .460
Detroit:    .277 .434
St.Louis:   .273 .425
Toronto:    .249 .413
Cincinnati: .256 .408
Colorado:   .258 .410
Arizona:    .250 .413
Kansas_City:.275 .415
====================
Big Ten Av: .266 .428

我的目标是让团队名称按字母顺序排序。我曾尝试使用 Array.sort() 方法以及使用 Comparator,但没有任何效果。我将包括我现在拥有的工作代码,任何帮助都会很棒!

package problem_1;

import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.text.DecimalFormat;
import java.util.Arrays;
import java.util.Comparator;

public class sluggers2 {

static String specificstat[][] = new String[1000][1000]; //Create a 2-dimensional array with limits of 1000
static DecimalFormat df = new DecimalFormat(".###");//Variable to round the integers to 3 decimal places

public static void main(String args[]) { //Main method
    execute(); //Call on the function "execute" and execute it
    baseballstats(1);
}

public static String[][] execute() {
    int line = 0;
    try {
        BufferedReader in = new BufferedReader(new FileReader("stuff/input_sluggers.txt"));

        String str;
        while ((str = in.readLine()) != null) {
            if (str.trim().length() == 0) {
                continue; // Skip blank lines
            }
            specificstat[line] = str.split(" ");
            line++;
        }
        in.close();
    } catch (IOException e) {
        System.out.println("Can not open or write to the file.");
    }
    return specificstat;
}

public static void baseballstats(int teamnumber) {
    double batting_average, slugging_average = batting_average = 0;

            //Arrays.sort(specificstat[0]);
            //Tried sorting the first dimension but it didn't work

    System.out.println(specificstat[0][0] + " " + specificstat[0][1] + " " + specificstat[0][2]);
    System.out.println("====================");

    while (teamnumber <= 10) {

        double B = Integer.parseInt(specificstat[teamnumber][5]);
        double C = Integer.parseInt(specificstat[teamnumber][6]);
        double D = Integer.parseInt(specificstat[teamnumber][7]);
        double A = Integer.parseInt(specificstat[teamnumber][4]) - (B + C + D);

        double slug_avg = ((A + 2*B + 3*C + 4*D) / Integer.parseInt(specificstat[teamnumber][2]));
        double y = Integer.parseInt(specificstat[teamnumber][4]), z = Integer.parseInt(specificstat[teamnumber][2]), bat_avg = y / z;

        slugging_average = slugging_average + slug_avg;
        batting_average = batting_average + bat_avg;

        double hits = Integer.parseInt(specificstat[teamnumber][4]);
        double at_bats = Integer.parseInt(specificstat[teamnumber][2]);

        String batting = df.format(hits / at_bats), slugging = df.format(slug_avg);

        if (slugging.length() == 3)
            slugging = slugging + "0";

        if (batting.length() == 3)
            batting = batting + "0";

        System.out.println(specificstat[teamnumber][0] + ":  " +  "\t" + batting + " " + slugging);
        teamnumber++;
    }

    String big_ten_av = "\t" + df.format(batting_average / 10) + " "+ df.format(slugging_average / 10);

    System.out.println("====================");
    System.out.print("Big Ten Av: "); System.out.print(big_ten_av);
}
}

我对编码比较陌生,所以任何帮助都将不胜感激。

4

2 回答 2

3

你需要这样的东西:

Arrays.sort( specificstat, new Comparator<String[]> {
    public int compare( String[] s1, String[] s2 ) {
        return s1[0].compareTo(s2[0]);
    }
} );

这基本上是说通过比较每个内部数组的第一个元素来对 specificstat 的内部数组进行排序......

于 2013-05-30T21:45:34.327 回答
1

Lucas 的另一种解决方案是完全消除 2d 数组,并使用某个类的数组,例如:

class TeamRecord implements Comparable {
  public String teamName;
  public ArrayList<Integer> stats;

  int compareTo(TeamRecord other) {
    return teamName.compareTo(other.teamName);    
  }

}

并改变你的:

static String specificstat[][] = new String[1000][1000];

至:

static TeamRecord specificstat[] = new TeamRecord[1000];

然后 Array.sort(specificstat) 将根据 teamName 进行排序。

这种方法的优点是它使您的数据更加清晰,因为团队名称实际上与统计数据不同;这里的类型立即清楚地表明了这一点。

我省略了将填充该数据类型的数组的代码,但我认为您可以弄清楚。

于 2013-05-30T22:02:02.023 回答