如何避免在break后j从n-i-1开始计算时的重复计算问题

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

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

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

img

以下是一个不使用指针的C语言示例代码,可以实现上述题目要求的功能:

#include <stdio.h>
#include <string.h>

#define MAX_NAME_LEN 9

int main()
{
    int n, i, j;
    char name[MAX_NAME_LEN];
    int sex, rank;

    scanf("%d", &n);

    // 定义两个变量,分别存储名次最靠前的女生和男生的姓名
    char female_name[MAX_NAME_LEN], male_name[MAX_NAME_LEN];

    // 定义两个变量,分别存储名次最靠前的女生和男生的名次
    int female_rank = 1, male_rank = n;

    for (i = 0; i < n; i++) {
        scanf("%d %s", &sex, name);
        rank = sex ? male_rank-- : female_rank++;

        if (rank % 2 == 0) { // 如果是偶数名次,即名次最靠前和名次最靠后的学生
            if (sex) { // 如果是男生,与名次最靠前的女生分组
                printf("%s %s\n", female_name, name);
            } else { // 如果是女生,与名次最靠后的男生分组
                printf("%s %s\n", name, male_name);
            }
        } else { // 如果是奇数名次,即还未分组的学生,更新名次最靠前的女生和名次最靠后的男生的姓名和名次
            if (sex) {
                strcpy(male_name, name);
            } else {
                strcpy(female_name, name);
            }
        }
    }

    return 0;
}


程序中,我们定义了两个字符串变量female_name和male_name,分别存储名次最靠前的女生和男生的姓名。同时,我们还定义了两个整型变量female_rank和male_rank,分别存储名次最靠前的女生和男生的名次。

在遍历学生时,如果当前学生的名次为偶数,即是名次最靠前的学生和名次最靠后的学生,则将其与名次最靠前的女生或名次最靠后的男生分组,并输出组员的姓名。如果当前学生的名次为奇数,即还未分组的学生,则更新名次最靠前的女生或名次最靠后的男生的姓名和名次,以备下次分组使用。

希望这个示例代码能够对您有所帮助。

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632不知道你这个问题是否已经解决, 如果还没有解决的话:

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^