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

C++信息学奥赛1178:成绩排序

在这里插入图片描述

#include<bits/stdc++.h>
using namespace std;
int main(){int n;cin>>n; // 输入整数 n,表示数组的大小int arr[n]; // 创建大小为 n 的整型数组 arrstring brr[n]; // 创建大小为 n 的字符串数组 brrfor(int i=0;i<n;i++) cin>>brr[i]>>arr[i]; // 依次读取字符串和整数,并存入对应的数组for(int i=0;i<n;i++){for(int j=0;j<n;j++){if(arr[i]>arr[j]){ // 先按照整数降序排序swap(brr[i],brr[j]);swap(arr[i],arr[j]);}if(arr[i]==arr[j]){ // 如果整数相同,则按照字符串的字典序升序排序if(brr[i]<brr[j]){swap(brr[i],brr[j]);swap(arr[i],arr[j]);        }}}}for(int i=0;i<n;i++) cout<<brr[i]<<" "<<arr[i]<<endl; // 按顺序输出排序后的字符串和整数return 0; // 返回 0 表示程序正常结束
}

返回代码逻辑:

  1. 首先,从标准输入中读取一个整数 n,表示数组的大小。
  2. 创建一个大小为 n 的整型数组 arr 和一个大小为 n 的字符串数组 brr。
  3. 使用 for 循环,从标准输入中依次读取 n 对元素,并将第一个字符串存入数组 brr 的对应位置,将第二个整数存入数组 arr 的对应位置。
  4. 使用嵌套的两个 for 循环,实现按照指定条件对数组 arr 和 brr 进行排序。首先按照整数降序排序,如果整数相同,则按照字符串的字典序升序排序。
  5. 使用 for 循环遍历排序后的数组,按照顺序输出字符串和整数。
  6. 程序结束,并返回 0 表示正常结束。
http://www.lryc.cn/news/155816.html

相关文章:

  • 【计算机视觉 | 目标检测】目标检测常用数据集及其介绍(七)
  • 100天精通Golang(基础入门篇)——第20天:Golang 接口 深度解析☞从基础到高级
  • ESXi 6.7添加螃蟹2.5g网卡支持
  • 机器学习笔记之最优化理论与方法(四) 凸函数:定义与基本性质
  • 【Git】git tag 查看版本号 | 删除本地 | 删除远程仓库| 批量删除
  • thinkphp:数据库查询,嵌套别的表的查询(别的表做子查询)
  • 《Linux 系统命令及Shell脚本实践指南》
  • 代码随想录算法训练营第三十八天 | ● 理论基础 ● 509. 斐波那契数 ● 70. 爬楼梯 ● 746. 使用最小花费爬楼梯
  • Java分别用BIO、NIO实现简单的客户端服务器通信
  • React Portals
  • Python基础之高级函数
  • CSS3常用的新功能总结
  • Lvs+KeepAlived高可用高性能负载均衡
  • 无涯教程-Android Online Test函数
  • 蓝桥杯打卡Day1
  • zipkin2.24.2源码install遇见的问题
  • yapi密码是如何生成的
  • 2023-09-02 LeetCode每日一题(最多可以摧毁的敌人城堡数目)
  • k8s环境部署配置
  • Java之文件操作与IO
  • 指令系统(408)
  • Pygame中Trivia游戏解析6-3
  • 热释电矢量传感器设计
  • MySql学习笔记10——视图介绍
  • 【探索Linux】—— 强大的命令行工具 P.7(进程 · 进程的概念)
  • JAVA宝典----容器(理解记忆)
  • JS中的扩展操作符...(点点点)
  • 找redis大key工具rdb_bigkeys
  • ElasticSearch进阶
  • Nor flash 页写地址与数据大小的限制