Домашнее задание: как отсортировать массив строк из файла - PullRequest
0 голосов
/ 25 октября 2018

Мне нужно написать программу, которая читает следующую информацию из файла.Столбцы: время в 1/100 секунды, номер ноты, скорость, длина.И каждая строка - это отдельная заметка. Мне нужно написать программу, которая их читает, а затем снова печатает.Я хочу иметь один открытый класс для Note и массив из них.

0 60 100 24
25 72 100 24
100 60 100 24
50 60 100 24
75 72 100 24

Это мой новый класс Note

открытый класс Note, реализующий Comparable {

private int time;
private int noteNumber;
private int velocity;
private int length;

public Note (int time, int noteNumber, int velocity, int length){

    this.time = time;
    this.noteNumber = noteNumber;
    this.velocity = velocity;
    this.length = length;

}


public String toString (){

    return String.format("(%s, %d, %d, %d)", time, noteNumber, velocity, length);
}

@Override
public int compareTo(Note note) {

    return this.time - note.time;
}

}

Это класс, который я использую для чтения строк из файла.Я могу правильно хранить только первую строку, но теперь у меня возникают проблемы при попытке сохранить другие строки.

открытый класс MelodyCatcher {

открытый статический Примечание [] n = новый Примечание [5];

public static void main(String[] args) throws IOException {

FileReader fr = new FileReader ("/Users/enricomomo/Desktop/Text/file1.txt");
    BufferedReader br = new BufferedReader (fr); //Info stored into a buffer

    String ln = null;
    while ((ln = br.readLine()) != null) {
    StringTokenizer st = new StringTokenizer(ln);
    while(st.hasMoreTokens()) // read each number in this line
    {

        n[0] = new Note(Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()));
        n[1] = new Note(Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()));
        n[2] = new Note(Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()));
        n[3] = new Note(Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()));
        n[4] = new Note(Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()));

    }

    System.out.println("The notes are " + Arrays.toString(n));
    Arrays.sort(n);
    System.out.println("The notes stored are " + Arrays.toString(n));
}

br.close();
fr.close();

}}

1 Ответ

0 голосов
/ 26 октября 2018

Итак, если ваши строки выглядят как в примере, вы можете просто разделить строку на объект Note, как показано ниже:

String[] noteParams = ln.split(" ");
Note n = new Note(noteParams[0], noteParams[1], noteParams[2], noteParams[3]);

Я могу изменить ваш код, как показано ниже, чтобы прочитать каждую строку и заполнить массив Note:

    String ln = null;
    while ((ln = br.readLine()) != null) {
        StringTokenizer st = new StringTokenizer(ln);
        while(st.hasMoreTokens()) // read each number in this line
        {

            n[0] = new Note(Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()));
            n[1] = new Note(Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()));
            n[2] = new Note(Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()));
            n[3] = new Note(Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()));
            n[4] = new Note(Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()),Integer.parseInt(st.nextToken()));

        }

        System.out.println("The notes are " + Arrays.toString(n));
        Arrays.sort(n);
        System.out.println("The notes stored are " + Arrays.toString(n));
    }

    br.close();
    fr.close();
...