蓝桥杯 使用sort排序(c++)

news2024/9/24 5:31:14

在这里插入图片描述

sort是一个C++已经为我们实现好的工具,当我们要用它时,需要先引入一个算法的库—— < algorithm >。需要说明的是,sort可以排序任何类型的元素,包括我们自己定义的结构体。
我们将需要在C++文件的开始位置加上:

#include <algorithm>

对于下面这段程序

#include<iostream>
#include<algorithm>
using namespace std;
int main(){
	int arr[]={2,4,5,3,1};
	return 0;
}

通过写

sort(arr,arr+5);

我们可以将arr中从开始的元素到第5个元素按从小到大的顺序排列。
而如果我们写:

sort(arr+i,arr+j);

那么被排序的将是arr[i]到arr[j-1],其他元素将保持原位置。

如果希望arr中的元素从大到小排列(或按照某一个规则进行排列),我们可以再为sort传入第三个参数——“排序方法”:

sort(arr,arr+5,greater<int>());

其中,greater表示“更大”的意思,表示待排序的数组中的元素类型为int,整个这行代码表示让一个元素类型为整数的数组从大到小排序。
我们的程序会变为:

#include<iostream>
#include<algorithm>
using namespace std;
int main(){
	int arr[]={2,4,5,3,1};
	sort(arr,arr+5,greater<int>());
	return 0;
}

在这里,我们可以看到,我们的程序声明了一个长
度为10的整数型数组,并通过循环从输入中读入10个整数。
接下来因为我们希望使用排序sort,所以请
用#include将< algorithm >库引入:
1 #include < algorithm >
请注意,我们习惯性地将所有引入操作放在程序最开始。在这里,你可以将< algorithm >在引入< iostream >之后一行引入。

#include <iostream>
#include <algorithm>
using namespace std;
int main(){
	int arr[10];
	for(int i=0;i<10;i++){
		cin>>arr[i];
	}
	sort(arr,arr+10);
	for(int i=0;i<10;i++){
		cout<<arr[i]<<" ";
	}
	cout<<endl;
	sort(arr,arr+10,greater<int>());
	for(int i=0;i<10;i++){
		cout<<arr[i]<<" ";
	}
	cout<<endl;
	return 0;
}

在这里插入图片描述

算出班上信息学成绩前K名的平均成绩。

编入格式
输入共有三行:
第一行:所在班级的人数N(其中1 ≤ N ≤ 30) ;
第二行:为N个用1个空格隔开的信息学分数(其中分数为700及以内正整数) ;
第三行:老师想计算平均数的尖子生人数K。
输出格式
输出一行共一个实数,为信息学分数前K名同学的分数平均数。四舍五入保留两位小数。
样例输入

10
93 85 77 68 59 100 43 94 75 82
4

样例输出

93.00
#include <iostream>
#include <algorithm>
using namespace std;
int score[35];
int main(){
	int N,k,sum;
	scanf("%d",&N);
	for(int i=0;i<N;i++){
		scanf("%d",&score[i]);
	}
	scanf("%d",&k);
	sort(score,score+N,greater<int>());
	sum=0;
	for(int i=0;i<k;i++){
		sum+=score[i];
	}
	printf("%.2f\n",1.0*sum/k);
	return 0;
}

在这里插入图片描述
小红所在的班级进行了数学考试,老师请小红同学帮忙进行名次排序和各分数段的人数统计工作。
现要求如下:将N名同学的考试成绩放在A数组中,各分数段的人数存到数组中:成绩为100的人数存到B[1]中,成绩为90到99的人数存
到B[2]中,成绩为80到89的人数存到B[3]中,成绩为70到79的人数存到B[4]中,成绩为60到69的人数存到B[5]中,成绩为60分以
下的人数存到B[6]中。
输入格式
输入共有两行:
第一行:为小红所在班级的人数N(其中1 <= N <=30) ;
·第二行:为N个用1个空格隔开的数学分数(其中分数为100及以内正整数)。
输出格式
输出共有若干行:
前N行:每行一个整数是从高到低排序的数学分数 ;
最后一行:是6个按要求,存放到数组B[1]到B[6]中各分数段的人数(各数据之间以1个业格为间隔)。
样例输入

10
93 85 77 68 59 100 43 94 75 82

样例输出

100
94
93
85
82
77
75
68
59
43
1 2 2 2 1 2
#include <iostream>
#include <algorithm>
using namespace std;
int score[35];
int B[7];
int main(){
	int N;
	scanf("%d",&N);
	for(int i=0;i<N;i++){
		scanf("%d",&score[i]);
	}
	sort(score,score+N,greater<int>());
	for(int i=0;i<N;i++){
		printf("%d\n",score[i]);
	}
	for(int i=0;i<N;i++){
		if(score[i]==100){
			B[1]++;
		}else if(score[i]>=90){
			B[2]++;
		}else if(score[i]>=80){
			B[3]++;
		}else if(score[i]>=70){
			B[4]++;
		}else if(score[i]>=60){
			B[5]++;
		}else{
			B[6]++;
		}
	}
	for(int i=1;i<=6;i++){
		if(i!=6){
			printf("%d ",B[i]);
		}else{
			printf("%d\n",B[i]);
		}
	}
	return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1074965.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux学习之认识操作系统

1.什么是操做系统&#xff1f; 操作系统实际上就是一个软件&#xff0c;是一个管理电脑硬件与软件资源的软件&#xff0c;同时也是计算机系统的内核与基石。 操作系统是一个庞大的管理控制程序&#xff0c;大致包括5个方面的管理功能&#xff1a;进程与处理机管理、作业管理、…

1. QEMU背景知识

QEMU的两种模拟方案&#xff1a; 系统模拟 System Simulation&#xff1a;可以简单的理解为对整个计算机系统进行模拟&#xff08;CPU、Memory等&#xff09; 用户模式模拟 User Mode Simulation&#xff1a;基于模拟方案执行特定应用程序 除了模拟功能外&#xff0c;QUME工具…

教资照片尺寸要求几寸 报考教资照片尺寸介绍

报考教资的照片要求是近期2寸正面免冠照片&#xff0c;并且白底彩色照片&#xff0c;照片的格式为ipg&#xff0c;要求照片的文件大小小雨200l&#xff0c;保证照片清晰&#xff0c;头部占照片驰尊的三分之二左右即可。 具体要求&#xff1a; 照片必须为本人近6个月以内的免冠…

437.路径总和III

法一&#xff1a;深度优先遍历&#xff0c;递归 rootSum(p,val)计算节点p向下且路径和为val的路径和rootSum(p,val)rootSum(p->left,val-pval)rootSum(p->right,val-pval)遍历二叉树所有节点的rootSum并求和 class Solution { public:int rootSum(TreeNode* node,long …

SpringCloud之Resilience4j熔断器源码解析

Hystrix官方已经停止开发了&#xff0c;Hystrix官方推荐使用新一代熔断器作为Resilience4j。作为新一代的熔断器&#xff0c;Resilience4j有很多优势&#xff0c;比如依赖少&#xff0c;模块化程度较好等优势。 Resilience4j是受Hystrix启发而做的熔断器&#xff0c;通过管理远…

Stm32_标准库_9_TIM

频率(HZ)是频率的基本单位1HZ是1s的倒数 STM32F103C8T6一般情况给定时器的内部时钟都是72MHz&#xff08;系统主频率&#xff09; TIM基本构成 计数器、预分频器、自动化重装 // 都是16位其中计数器、自动化重装&#xff0c;都是16位换算成10进制范围为[0, 655536] 时间 1 /…

【Es基础入门必看】

Es基础入门 1. ElasticSearch的认知1.1 搜索1.2 倒排索引1.3 Lucene1.4 ES基本概念 1. ElasticSearch的认知 ElasticSearch&#xff08;以下简称ES&#xff09;是什么&#xff1f;按照官网的定义&#xff0c;ElasticSearch是一个分布式的、RESTFUL风格的搜索引擎。 1.1 搜索…

浅谈go语言的错误处理

前言 本文是探讨的是"go语言中如何优雅地处理错误" 观察go语言源码 在go语言的内置函数中,很多的函数都会返回一个error,特别是在与文件读写操作的相关的函数的时候,基本上都会有返回error,返回这个的好处是用来辨别是否出错,把结果直接告诉你,以便你进行下一步操…

64.最小路径和

法&#xff1a;动态规划 第一行的元素&#xff0c;只有通过左侧右移才能到达&#xff1b;第一列的元素&#xff0c;只有通过上方的下移才能到达。其他位置元素&#xff1a;比较从上方元素向下移动的路径和和左侧元素向右移动的路径和的较小值dp[i][j]&#xff1a;到达(i,j)位置…

【数据分类】基于麻雀搜索算法优化支持向量机的数据分类方法 SSA-SVM分类算法【Matlab代码#61】

文章目录 【可更换其他群智能算法&#xff0c;获取资源请见文章第6节&#xff1a;资源获取】1. 麻雀搜索算法&#xff08;SSA&#xff09;2. 支持向量机&#xff08;SVM&#xff09;3. SSA-SVM分类模型4. 部分代码展示5. 仿真结果展示6. 资源获取 【可更换其他群智能算法&#…

Jmeter 链接MySQL测试

1.环境部署 1.1官网下载MySQL Connector https://dev.mysql.com/downloads/connector/j/ 1.2 解压后&#xff0c;将jar放到jmeter/lib目录下 1.3 在测试计划中添加引用 2.脚本设置 2.1设置JDBC Connection Configuration 先添加一个setUp线程中&#xff0c;在setUp中添加“…

Git知识整理(持续更新)

一、跨系统配置之CSLF和LF Windows系统中&#xff0c;从第n行到第n1行&#xff0c;用的是回车\r加换行\n&#xff0c;即Carriage Return和Line Feed。 Mac和Linux系统中&#xff0c;从第n行到第n1行&#xff0c;只用了换行\n&#xff0c;即Line Feed。 git有CRLF机制&#xf…

基于springboot实现准妈妈孕期交流平台项目【项目源码+论文说明】

基于springboot实现准妈妈孕期交流平台演示 摘要 随着科学技术的飞速发展&#xff0c;社会的方方面面、各行各业都在努力与现代的先进技术接轨&#xff0c;通过科技手段来提高自身的优势&#xff0c;准妈妈孕期交流平台当然也不能排除在外。准妈妈孕期交流平台是以实际运用为开…

【UE5 Cesium】16-Cesium for Unreal 建立飞行跟踪器(1)

目录 步骤 一、关卡准备 二、UE读取存有航线点迹的CSV文件 三、程序化CesiumCartographicPolygon的点 步骤 一、关卡准备 1. 在Cesium For Unreal官网找到“San Francisco international Airport”的经纬度如下&#xff1a; 在“CesiumGeoreference”中设置相应的经纬度 …

软件开发进度的有效管控方法和技巧

对于软件开发而言&#xff0c;进度把控十分重要。如果无法即时跟踪进度&#xff0c;就无法获知项目计划的进展&#xff0c;团队通常会在此过程中失去动力。 Zoho Projects 结合IT行业特点运用项目管理技术、理念和方法&#xff0c;包括9大知识领域&#xff08;项目综合、范围、…

各类高危漏洞介绍及验证方式教程(一)

本期整理的漏洞验证教程约包含50多类漏洞&#xff0c;分多个章节编写&#xff0c;可从以下链接获取全文&#xff1a; 各类高危漏洞验证方式.docx (访问密码: 1455) 搭建dvwa测试环境基础教程.docx(访问密码: 1455) web逻辑漏洞挖掘快速入门基础教程.docx(访问密码: 1455) 01 Ca…

【面试算法——动态规划 21】不同的子序列(hard) 通配符匹配(hard)

115. 不同的子序列 给你两个字符串 s 和 t &#xff0c;统计并返回在 s 的 子序列 中 t 出现的个数&#xff0c;结果需要对 109 7 取模。 链接&#xff1a;&#xff1a;https://leetcode.cn/problems/distinct-subsequences/ 示例 1&#xff1a; 输入&#xff1a;s “rab…

FreeRTOS自我救赎1之基本知识

每次写博客都是先用完了知识再写&#xff0c;也是很无奈&#xff0c;因为面试的时候我只会操作但我不会说&#xff0c;多写博客才能会“吹”。 1.目录结构 不好评价&#xff0c;我的目录结构是cubemx生成的&#xff0c;其中BSP_Device存储了一些模块化后的中间层代码 1.1核心…

【Java 进阶篇】使用Druid数据库连接池工具类进行测试

在前面的博客中&#xff0c;我们已经介绍了如何配置和使用Druid数据库连接池。现在&#xff0c;让我们来学习如何编写测试代码&#xff0c;以确保Druid连接池的正常运行。 步骤1&#xff1a;创建测试表 首先&#xff0c;我们需要创建一个测试用的数据库表&#xff0c;以便在示…

MongoDB——centOS7安装mongodb5.0.21版本服务端(图解版)

目录 一、mongodb官网下载地址二、安装步骤2.1、上传安装包并解压2.2、配置环境变量2.3、创建目录并授权2.4、创建配置文件2.5、启动MongoDB 三、开放端口四、客户端连接 一、mongodb官网下载地址 mongodb官网下载地址&#xff1a;https://www.mongodb.com/try/download/commu…