当前位置: 首页 > news >正文

c 语言基础题目:PTA L1-030 一帮一

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

输入格式:

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

输出格式:

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

输入样例:

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

输出样例:

Amy Jack
Tom Linda
Bill Maya
Cindy John

程序源码:

#include<stdio.h> // 引入标准输入输出库,这个库提供了scanf和printf等输入输出函数  struct S // 定义一个名为S的结构体  
{  int sex; // 结构体中的sex字段,存储学生的性别,整数表示  char name[9]; // 结构体中的name字段,存储学生的名字,是一个可以容纳9个字符的字符数组  
};  int main() // 定义主函数,程序的执行从这里开始  
{  struct S stu[50]={0}; // 定义一个S类型的数组stu,包含50个元素,并且所有元素被初始化为0,代表没有学生的配对  int n = 0; // n用来存储用户输入的学生数量,初始化为0  scanf("%d",&n); // 从用户处读取学生数量  int i = 0; // i是用来循环遍历学生的索引  // 使用for循环读取n个学生的信息  for(i=0;i<n;i++)  {  scanf("%d %s",&stu[i].sex,stu[i].name); // 从用户处读取学生的性别和名字,输入格式是两个整数和一个字符串  }  // 使用另一个for循环来查找所有的学生配对  for(i=0;i<n;i++)  {  int j = 0; // j用来遍历除了i以外的所有学生  for(j=n-1;j>i;j--) // 从最后一个学生开始向前遍历到i前面的学生  {  if(stu[i].sex!=stu[j].sex && stu[j].sex!=-1) // 如果找到一个与i学生性别不同的j学生,并且这个j学生的性别没有被标记为-1(表示还没有找到配对)  {  printf("%s %s\n",stu[i].name,stu[j].name); // 打印出这两个学生的名字  stu[j].sex=-1; // 将j学生的性别标记为-1,表示这个学生已经被配对了  break; // 跳出内层循环,不需要再查找这个j学生的其他配对了  }  }  }  return 0; // 主函数返回0,表示程序正常结束  
}

http://www.lryc.cn/news/187843.html

相关文章:

  • 网工内推 | base郑州,上市公司,最高15薪,五险一金全额缴
  • 求后缀表达式的值
  • 【FISCO-BCOS】十七、角色的权限控制
  • vue怎样封装接口
  • Typescript 笔记:函数
  • Axios 封装
  • CocosCreator 面试题(一)Javascript的垃圾回收机制
  • 【计算机网络】UDP协议编写群聊天室----附代码
  • Java架构师高并发架构设计
  • 【客观赋权法1】熵权法(MATLAB全代码)
  • “注释: 爱恨交织的双重标准?解析注释在代码开发中的作用。”
  • 一种基于局部适应度景观的进化规划的混合策略
  • Python数据攻略-Mongodb数仓无法写入方法汇总
  • 用什么工具来画UML?
  • SQLite3数据类型
  • K8S:K8S对外服务之Ingress
  • flask入门
  • 掌动智能:性能测试工具优势有哪些
  • 实现一个简单的线性回归和多项式回归(2)
  • 云原生Kubernetes:K8S集群kubectl命令汇总
  • Java使用模板导出word、pdf
  • 速通Redis基础(二):掌握Redis的哈希类型和命令
  • WebDAV之π-Disk派盘 + 书藏家
  • 香港Web3.0生态现状
  • LLMs之BELLE:源码解读(sft_train.py文件)
  • 【UE5 Cesium】17-Cesium for Unreal 建立飞行跟踪器(2)
  • 【ElasticSearch】基于 Java 客户端 RestClient 实现对 ElasticSearch 索引库、文档的增删改查操作,以及文档的批量导入
  • 【Node.js】stream 流模块
  • 【LeetCode】——链式二叉树经典OJ题详解
  • 代码注释对于程序员重要吗?