Skip to content

L1-030 一帮一

“一帮一学习小组”是中小学中常见的学习组织方式,老师把学习成绩靠前的学生跟学习成绩靠后的学生排在一组。本题就请你编写程序帮助老师自动完成这个分配工作,即在得到全班学生的排名后,在当前尚未分组的学生中,将名次最靠前的学生与名次最靠后的异性学生分为一组。

输入格式:

输入第一行给出正偶数N(≤50),即全班学生的人数。此后N行,按照名次从高到低的顺序给出每个学生的性别(0 代表女生,1 代表男生)和姓名(不超过 8 个英文字母的非空字符串),其间以 1 个空格分隔。这里保证本班男女比例是 1:1,并且没有并列名次。

输出格式:

每行输出一组两个学生的姓名,其间以 1 个空格分隔。名次高的学生在前,名次低的学生在后。小组的输出顺序按照前面学生的名次从高到低排列。

输入样例:

tex
8
0 Amy
1 Tom
1 Bill
0 Cindy
0 Maya
1 John
1 Jack
0 Linda
8
0 Amy
1 Tom
1 Bill
0 Cindy
0 Maya
1 John
1 Jack
0 Linda

输出样例:

tex
Amy Jack
Tom Linda
Bill Maya
Cindy John
Amy Jack
Tom Linda
Bill Maya
Cindy John

Solution:

java
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
        int n = Integer.parseInt(in.readLine());
        List<Student> list = new ArrayList();
        for (int i = 0; i < n; i++) {
            String[] input = in.readLine().split(" ");
            list.add(new Student(input[0], input[1]));
        }
        StringBuilder sb = new StringBuilder();
        int count = n / 2;
        for (int i = 0; i < count; i++) {
            for (int j = list.size() - 1; j >= count; j--) {
                if (!list.get(j).sex.equals(list.get(i).sex)) {
                    sb.append(list.get(i).name).append(" ").append(list.get(j).name).append("\n");
                    list.remove(j);
                    break;
                }
            }
        }
        System.out.print(sb);
    }
}

class Student {
    String sex;
    String name;

    public Student(String sex, String name) {
        this.sex = sex;
        this.name = name;
    }
}
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
        int n = Integer.parseInt(in.readLine());
        List<Student> list = new ArrayList();
        for (int i = 0; i < n; i++) {
            String[] input = in.readLine().split(" ");
            list.add(new Student(input[0], input[1]));
        }
        StringBuilder sb = new StringBuilder();
        int count = n / 2;
        for (int i = 0; i < count; i++) {
            for (int j = list.size() - 1; j >= count; j--) {
                if (!list.get(j).sex.equals(list.get(i).sex)) {
                    sb.append(list.get(i).name).append(" ").append(list.get(j).name).append("\n");
                    list.remove(j);
                    break;
                }
            }
        }
        System.out.print(sb);
    }
}

class Student {
    String sex;
    String name;

    public Student(String sex, String name) {
        this.sex = sex;
        this.name = name;
    }
}

Released under the MIT License.