博客
关于我
7-6 一帮一
阅读量:704 次
发布时间:2019-03-21

本文共 842 字,大约阅读时间需要 2 分钟。

一帮一学习小组是中小学常见的学习组织方式,教师通常会将学习成绩靠前的学生与学习成绩靠后的学生分为一组。本题要求编写程序,帮助老师自动完成学生分组工作。具体任务是在已知全班学生的排名后,在尚未分组的学生中,将名次最靠前的学生与名次最靠后的异性学生分为一组。

输入第一行给出正偶数N(≤50),表示全班学生的人数。接下来的N行依次列出了每个学生的性别(0代表女生,1代表男生)和姓名(不超过8个英文字母的非空字符串),信息之间用1个空格分隔。保证本班男女比例为1:1,且名次排名无并列。

输出格式要求,每行输出一组两个学生的姓名,名次高的学生在前,名次低的学生在后。输出中组的顺序按前面学生的名次由高到低排列。

输入样例:

80 Amy1 Tom1 Bill0 Cindy0 Maya1 John1 Jack0 Linda

输出样例:

Amy JackTom LindaBill MayaCindy John

注:上述程序可通过以下方式实现:

#include 
#include
#include
#include
using namespace std;struct student { int sex; char name[200];};int main() { int n, i, j; cin >> n; for (i = 0; i < n; ++i) { cin >> s[i].sex >> s[i].name; } int vis[1000]; memset(vis, 0, sizeof(vis)); for (i = 0; i < n; ++i) { // 这里的逻辑为:配对次学生 } return 0;}所有学生按照排名从高到低排序后,程序将每个较高排名的学生与对应的较低排名的异性学生配对。

转载地址:http://hfoez.baihongyu.com/

你可能感兴趣的文章
Navicat下载和破解以及使用
查看>>
Navicat中怎样将SQLServer的表复制到MySql中
查看>>
navicat创建连接 2002-can‘t connect to server on localhost(10061)且mysql服务已启动问题
查看>>
Navicat可视化界面导入SQL文件生成数据库表
查看>>
Navicat向sqlserver中插入数据时提示:当 IDENTITY_INSERT 设置为 OFF 时,不能向表中的标识列插入显式值
查看>>
Navicat因导入的sql文件中时间数据类型有参数而报错的原因(例:datetime(3))
查看>>
Navicat如何连接MySQL
查看>>
navicat导入.sql文件出错2006- MySQLserver has gone away
查看>>
Navicat工具Oracle数据库复制 or 备用、恢复功能(评论都在谈论需要教)
查看>>
navicat怎么导出和导入数据表
查看>>
Navicat报错:1045-Access denied for user root@localhost(using passwordYES)
查看>>
Navicat通过存储过程批量插入mysql数据
查看>>
Navicat(数据库可视化操作软件)安装、配置、测试
查看>>
NB-IOT使用LWM2M移动onenet基础通信套件对接之APN设置
查看>>
NBear简介与使用图解
查看>>
nc命令详解
查看>>
ndk特定版本下载
查看>>
NDK编译错误expected specifier-qualifier-list before...
查看>>
Neat Stuff to Do in List Controls Using Custom Draw
查看>>
Necurs僵尸网络攻击美国金融机构 利用Trickbot银行木马窃取账户信息和欺诈
查看>>