对字符串数组和int数组进行排序

Ran*_*guy 2 java arrays sorting

我正在练习数组排序,我已经成功排序了一个字符串数组.

我的小程序允许用户输入第一批学生,然后输入每个学生的名字,最后输入每个学生的成绩.

但是我也想对int studentGrade数组进行排序,以便打印输出中的成绩与学生匹配.在这里,我真的被困住了.有关详细说明,请参阅下面的方法: public void sortingAlgorithm

package assignment8exam;

import java.util.Scanner;
import java.util.Arrays;

/**
 *
 * @author Anders
 */
public class Course {

    Scanner sc = new Scanner(System.in);

    public void MainMenu() {

        System.out.println("Enter data about a student, start by entering how many");

        int numbers = sc.nextInt();// amount of student
        String studentNames[] = new String[numbers];
        int studentGrade[] = new int[numbers];
        for (int i = 0; i < numbers; i++) {

            System.out.println("Enter name of student");
            Scanner name = new Scanner(System.in);

            String names = name.nextLine();
            studentNames[i] = names;
        }

        for (int j = 0; j < numbers; j++) {

            System.out.println("Enter grade of student");
            Scanner gradeSc = new Scanner(System.in);

            int grade = gradeSc.nextInt();
            studentGrade[j] = grade;
        }

        sortingArray(studentNames);
        System.out.println("------------------------------------\n");
        sortAlgorithm(studentNames, studentGrade);
        System.out.println("What do you want");
        System.out.println("Exit application 1");
        System.out.println("Print out all names of the students 2");
        System.out.println("Print out all the grades of the students 3");
        System.out.println("Print out pairs consisting of “name­grade 4");
        System.out.println("Search for a student - 5");
        Scanner choice = new Scanner(System.in);
        int order = choice.nextInt();

        switch (order) {

            case 1:
                System.exit(1);

            case 2:
                PrintOutNames(numbers, studentNames);

            case 3:
                PrintOutGrades(numbers, studentGrade);

            case 4:
                PrintOutAll(numbers, studentGrade, studentNames);

            case 5:
                search(numbers, studentGrade, studentNames);

        }

    }

    public static void PrintOutNames(int numbers, String studentNames[]) {

        for (int i = 0; i < numbers; i++) {

            System.out.println(studentNames[i]);

        }
    }

    public static void PrintOutGrades(int numbers, int studentGrade[]) {

        for (int i = 0; i < numbers; i++) {

            System.out.println(studentGrade[i]);

        }

    }

    public static void PrintOutAll(int numbers, int studentGrade[], String studentNames[]) {
        System.out.println("--------------------------------------------------------\n");
        for (int i = 0; i < numbers; i++) {

            System.out.println("Name----> " + studentNames[i] + " grade ---> " + studentGrade[i]);

        }

    }

    public static void search(int numbers, int studentGrade[], String studentNames[]) {
        Scanner sc = new Scanner(System.in);
        System.out.println("Enter name on student you want to search on ");
        String search = sc.nextLine();
        for (int i = 0; i < numbers; i++) {

            if (search.equals(studentNames[i])) {

                System.out.println("Yes we have a student named " + studentNames[i] + " with the Grade " + studentGrade[i] + " \n ");

            }

        }
    }

    public static void sortingArray(String studentNames[]) {

        Arrays.sort(studentNames);
        System.out.println("-------------\n" + Arrays.toString(studentNames));

    }

    public static void sortAlgorithm(String studentNames[], int studentGrade[]) {

        boolean flag = true;

        while (flag) {

            flag = false;

            for (int j = 0; j < studentNames.length - 1; j++) {

                for (int i = j + 1; i < studentNames.length; i++) {
                    if (studentNames[i].compareTo(studentNames[j]) < 0) {
                        String temp = studentNames[j];
                        studentNames[j] = studentNames[i];
                        studentNames[i] = temp;

                                                                                             // Here i want to place another array that sorts the grade?? how do i do that?
                    }

                }

                System.out.println(Arrays.toString(studentNames));
                System.out.println(Arrays.toString(studentGrade));

            }
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

Ves*_*dov 5

您的方法存在的问题是学生姓名和成绩之间没有关系.如果您对姓名进行排序并对成绩进行排序,您最终会得到字母A成绩最低的学生.

如果这是一个java赋值,最好的方法是创建一个名为Student的数据结构(类),它具有名称和等级.

class Student{
 String name;
 int grade;
}
Run Code Online (Sandbox Code Playgroud)

那么你将不会有两个数组,一个有名字,另一个有成绩,但只有一个学生数组,你可以按等级,名称等对数组进行排序.

如果你想要一个更快的解决方案,那就是使用这样的地图Map<String,Integer>将包含每个学生的成绩.

如果要使用多个数组,可以使sortAlgorithm方法在两个数组中交换相同的索引(不仅在names数组中),这样您最终会得到按名称排序的等级.这是IMO最糟糕的方法,因为您过分依赖数组索引而不是在对象之间建立某种关系.