以下是一个不使用指针的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,分别存储名次最靠前的女生和男生的名次。
在遍历学生时,如果当前学生的名次为偶数,即是名次最靠前的学生和名次最靠后的学生,则将其与名次最靠前的女生或名次最靠后的男生分组,并输出组员的姓名。如果当前学生的名次为奇数,即还未分组的学生,则更新名次最靠前的女生或名次最靠后的男生的姓名和名次,以备下次分组使用。
希望这个示例代码能够对您有所帮助。