信奥赛一本通:数据排序(合影效果、病人排队、明明的随机数、单词排序、出现次数超过一半的数、统计字符数)

news2025/1/12 23:28:52

数据排序

    • 1182:合影效果
    • 1183:病人排队
    • 1184:明明的随机数
    • 1185:单词排序
    • 1186:出现次数超过一半的数
    • 1187:统计字符数

1182:合影效果

在这里插入图片描述
由题目可知,n个人有 性别与身高两种属性,则我们用结构体去做。

  1. 定义结构体,并输入值。
struct Student{
	string sex;
	double high;
};
int main(){
	Student stu[105];
	int n;
	cin>>n;
	for(int i=0;i<n;i++){
		cin>>stu[i].sex>>stu[i].high;
	}
  1. sort排序,依据男在左,女在右。当性别一致,则按身高排序,男生身高从小到大,女生则从高到低。
bool cmp(Student x,Student y){
	if(x.sex!=y.sex){
		return x.sex>y.sex;
	}
	else{
		if(x.sex=="male"){
			return x.high<y.high;
		}
		return x.high>y.high;
	}
}
  1. 最后输出
    总代码:
//1182:合影效果
#include<bits/stdc++.h>
using namespace std;
struct Student{
	string sex;
	double high;
};
bool cmp(Student x,Student y){
	if(x.sex!=y.sex){
		return x.sex>y.sex;
	}
	else{
		if(x.sex=="male"){
			return x.high<y.high;
		}
		return x.high>y.high;
	}
}
int main(){
	Student stu[105];
	int n;
	cin>>n;
	for(int i=0;i<n;i++){
		cin>>stu[i].sex>>stu[i].high;
	}
	sort(stu,stu+n,cmp);
	for(int i=0;i<n;i++){
		printf("%.2f ",stu[i].high);
	}
	return 0;
}

1183:病人排队

在这里插入图片描述
根据题目:我们可分为老年人看病 与 非老年人看病 的排队顺序。病人有病号与年龄两个属性。老规矩用结构体。

  1. 一个病人要有ID、年龄、排号顺序。定义结构体并输入;
struct Per{
	string id;
	int age,num;
};

int main(){
	Per p[105];
	Per a[105], b[105]; //a是老年人 b是非老年人
	int n,len1=1,len2=1;	
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>p[i].id>>p[i].age;
	}
  1. 通过判断年龄>=60,进行分类,老年人a数组, 非老年人b数组。
	for(int i=1;i<=n;i++){
		if(p[i].age>=60){
			a[len1].num = len1;
			a[len1].age = p[i].age;
			a[len1++].id = p[i].id;
		}
		else{
			b[len2++].id = p[i].id;
		}
	}

3.对a数组老年人进行sort排序,年龄从大到小,当年龄相同按排号登记顺序先后。

bool cmp(Per x,Per y){
	if(x.age!=y.age) return x.age>y.age;
	else if(x.age==y.age) return x.num<y.num;
}

sort(a+1,a+1+len1,cmp);

4.排完序后,进行输出,先输出老年人再输出非老年人。

for(int i=1;i<len1;i++) cout<<a[i].id<<endl;
for(int j=1;j<=len2;j++) cout<<b[j].id<<endl;

总代码:

//1183:病人排队
#include<bits/stdc++.h>
using namespace std;
struct Per{
	string id;
	int age,num;
};
bool cmp(Per x,Per y){
	if(x.age!=y.age) return x.age>y.age;
	else if(x.age==y.age) return x.num<y.num;
}
int main(){
	Per p[105];
	Per a[105], b[105];
	int n,len1=1,len2=1;	
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>p[i].id>>p[i].age;
	}
	for(int i=1;i<=n;i++){
		if(p[i].age>=60){
			a[len1].num = len1;
			a[len1].age = p[i].age;
			a[len1++].id = p[i].id;
		}
		else{
			b[len2++].id = p[i].id;
		}
	}
	sort(a+1,a+1+len1,cmp);
	for(int i=1;i<len1;i++) cout<<a[i].id<<endl;
	for(int j=1;j<=len2;j++) cout<<b[j].id<<endl;
	return 0;
} 

1184:明明的随机数

在这里插入图片描述在这里插入图片描述
由题目可知,去重与排序,我们可用 “桶排序” 做,很方便。

  1. 统计桶的数量,这样每个桶的值只输出一次,那就不会有重复的!
#include<bits/stdc++.h>
using namespace std;
int a[10000],b[10000]; //默认数组值0 
int main(){
	//4.桶排序
	int n,x,cnt=0;
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>x; // 4 4 5 9 
		a[x]=a[x]+1; //统计桶的数量 
	} 
  1. 判断有桶号,只执行一次,就可以去重
	for(int i=0;i<1000;i++) {
		if(a[i]>0){ //有数量 
			b[cnt++]=i; //b去重 排好序 
		}
	}
  1. 最后输出个数与值。
    总代码:
#include<bits/stdc++.h>
using namespace std;
int a[10000],b[10000]; //默认数组值0 
int main(){
	//4.桶排序
	int n,x,cnt=0;
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>x; // 4 4 5 9 
		a[x]=a[x]+1; //统计桶的数量 
	} 
	for(int i=0;i<1000;i++) {
		if(a[i]>0){ //有数量 
			b[cnt++]=i; //b去重 排好序 
		}
	}
	cout<<cnt<<endl;
	for(int i=0;i<cnt;i++){
		cout<<b[i]<<" ";
	} 
	return 0;
}

1185:单词排序

在这里插入图片描述在这里插入图片描述
由题目可知,需要输入多个字符串,我们可以定义字符串的数组s进行输入。
用到一维数组的输入,排序我们直接用sort即可。
但是我们重复的只能输出一次,那排序后,重复的单词会在相邻位置,只要判断数组前一个与后一个的值不等就存到另外一个数组ss。
遍历完所有字符串就,输出数组ss。

//1185:单词排序
#include<bits/stdc++.h>
using namespace std;
int main(){
	int i=0,k=0;
	string s[105],ss[105];
	while(cin>>s[i]){
		i++;
	}
	sort(s,s+i);
	for(int j=1;j<i;j++){
		if(s[j-1]!=s[j]) ss[k++]=s[j-1];
	}
	if(s[i-2]!=s[i-1]) ss[k++] = s[i-1];
	for(int i=0;i<k;i++){
		cout<<ss[i]<<endl;
	}
	return 0;
} 
//1185:单词排序
#include<bits/stdc++.h>
using namespace std;
int main(){
	int i=0,k=0;
	string s[105];
	while(cin>>s[i]){
		i++;
	}
	sort(s,s+i);
	for(int j=1;j<=i;j++){
		if(s[j-1]!=s[j]){
			cout<<s[j-1]<<endl;
		}
	}
	return 0;
} 

1186:出现次数超过一半的数

在这里插入图片描述在这里插入图片描述
通过题目可知,我们要找次数超过一半的数,那我们要统计每个数的次数,可用桶排序;但要注意,数组的值是有-50的,所以我们可以让每个数组编号+50再统计。

int x,b[1005]={0};
int main(){
	int n,flag=0;
	cin>>n; 
	for(int i=0;i<n;i++){
		cin>>x;
		b[x+50]++; //注意数值有负 
	}

统计完只要在0到1000值内判断,数组值>n/2,就可以输出 编号值-50。
注意细节,要是没有满足if条件则没有找到,要输出no。

//1186:出现次数超过一半的数
#include<bits/stdc++.h>
using namespace std;
int x,b[1005]={0};
int main(){
	int n,flag=0;
	cin>>n; 
	for(int i=0;i<n;i++){
		cin>>x;
		b[x+50]++; //注意数值有负 
	}
	for(int i=0;i<1000;i++){
		if(b[i]>n/2){
			cout<<i-50<<endl;
			flag=1; 
			break;
		}
	}
	if(flag==0){
		cout<<"no"<<endl;
	}
	return 0;
} 

1187:统计字符数

在这里插入图片描述
统计个数,现在我们可以用桶排序方便。统计完每个字母的次数,我们在从a到z判断哪个字母的次数最多,找出来最大值。

//1187:统计字符数
#include<bits/stdc++.h>
using namespace std;
int b[1000];
int main(){
	string s;
	char c;
	int max=0;
	
	cin>>s;
	for(int i=0;i<s.size();i++){
		b[s[i]]++;	
	} 
	for(int i='a';i<='z';i++){
		if(max<b[i]){
			max = b[i]; //记录数量最大值 
			c=i; 
		}
	}
	cout<<c<<" "<<max<<endl;
	return 0;
} 

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

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

相关文章

java连接mysql数据库结构表批量生产word文档

java连接数据库&#xff0c;数据库结构表批量生产word文档 pom包引用 <dependency><groupId>cn.smallbun.screw</groupId><artifactId>screw-core</artifactId><version>1.0.5</version> </dependency><dependency>&l…

一句话解释什么是出口IP

出口 IP 是指从本地网络连接到公共互联网时所使用的 IP 地址。这个 IP 地址是由 Internet 服务提供商(ISP)分配给你的,它可以用来标识你的网络流量的来源。如果你使用的是 NAT(网络地址转换)技术,则在 NAT 设备内部会进行地址转换,使得多个设备可以共享同一个公共 IP 地…

功能不够,SQL来凑,修改数据库的正确姿势?

修改数据库是一项关键任务&#xff0c;需要小心谨慎地执行&#xff0c;以确保数据的完整性和准确性。下面是一个详细的步骤指南&#xff0c;介绍了正确修改数据库的姿势。 第一步&#xff1a;备份数据库 在进行任何数据库修改之前&#xff0c;务必备份数据库。这样&#xff0…

TOUGH模型教程

详情点击公众号链接&#xff1a;全流程TOUGH系列软件 一、 第一&#xff1a;多相流流体基本特征及TOUGH系列软件 1.1多相流流体基本特征与解决思路 1.2 TOUGH2系列软件 1.3 TOUGH2软件功能模块 1.4 TOUGH2软件设计思路 1.5 TOUGH2软件数学模型与数值方法 二、基础 第二&…

HarmonyOS 音频开发指导:使用 OpenSL ES 开发音频播放功能

OpenSL ES 全称为 Open Sound Library for Embedded Systems&#xff0c;是一个嵌入式、跨平台、免费的音频处理库。为嵌入式移动多媒体设备上的应用开发者提供标准化、高性能、低延迟的 API。HarmonyOS 的 Native API 基于Khronos Group开发的OpenSL ES 1.0.1 API 规范实现&am…

全志R128基础组件开发指南——SPI LCD 显示驱动

SPI LCD 显示驱动 简介 R128 平台提供了 SPI DBI 的 SPI TFT 接口ACCC&#xff0c;具有如下特点&#xff1a; Supports DBI Type C 3 Line/4 Line Interface ModeSupports 2 Data Lane Interface ModeSupports data source from CPU or DMASupports RGB111/444/565/666/888 …

买学生台灯主要看什么?双十一值得入手的学生台灯

对于台灯来说主要是光源的问题。随着科技时代发展&#xff0c;那种原有的白炽灯&#xff0c;钨丝灯早已不见&#xff0c;换言之是更多的LED灯&#xff0c;再加之它体积小便于安装&#xff0c;而且光线更加均匀柔和&#xff0c;所以深受用户的青睐。 而台灯又是孩子学习必不可少…

2023年【汽车驾驶员(中级)】报名考试及汽车驾驶员(中级)证考试

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 汽车驾驶员&#xff08;中级&#xff09;报名考试根据新汽车驾驶员&#xff08;中级&#xff09;考试大纲要求&#xff0c;安全生产模拟考试一点通将汽车驾驶员&#xff08;中级&#xff09;模拟考试试题进行汇编&…

Shopee买家通系统全自动化操作简单方便又快速

Shopee买家通系统是一款专门针对虾皮买家号所开发的全自动化操作系统&#xff0c;可以自动注册、自动加购加心愿单、自动下单等。 1、全自动化注册 准备好账号需要的资料后即可运行注册任务&#xff0c;程序运行时可以自动输入手机号、自动接收短信、自动输入账号密码。账号支…

浙大陈越何钦铭数据结构06-图1 列出连通集

题目 给定一个有N个顶点和E条边的无向图&#xff0c;请用DFS和BFS分别列出其所有的连通集。假设顶点从0到N−1编号。进行搜索时&#xff0c;假设我们总是从编号最小的顶点出发&#xff0c;按编号递增的顺序访问邻接点。 输入格式: 输入第1行给出2个整数N(0<N≤10)和E&…

2023年9月青少年机器人技术(四级)等级考试试卷-理论综合

2023.9青少年机器人技术等级考试理论综合试卷&#xff08;四级&#xff09; 分数&#xff1a;100 题数&#xff1a;30 一、单选题(共20题&#xff0c;共80分) 1. Arduino C程序如下&#xff0c;当程序运行时&#xff0c;串口监视器输出结果是&#xff1f;&#xff08; &…

微信视频号怎么下载视频?

微信视频号视频和其他平台有个最大的区别就是&#xff0c;没有链接&#xff0c;其他的下载器无法解析&#xff0c;知道我发现了一款非常适用于微信的下载工具&#xff0c;只需要将视频转发下载机器人就能一键解析成功&#xff0c;这么听着有点不懂对不对&#xff1f;别急&#…

【C++代码】回溯,子集,组合,全排列,去重--代码随想录

题目&#xff1a;分割回文串 给你一个字符串 s&#xff0c;请你将 s 分割成一些子串&#xff0c;使每个子串都是 回文串 。返回 s 所有可能的分割方案。回文串 是正着读和反着读都一样的字符串。 在for (int i startIndex; i < s.size(); i)循环中&#xff0c;我们 定义了…

app开发者提升第四季度广告收入的方法

第四季度将迎来双十一、双十二、圣诞、元旦为主的电商购物季&#xff0c;这是一年中利用线上消费为全新年度和全新预算做好准备的最佳时机&#xff0c;从过往的变现成功案例中汇总了优化要点&#xff0c;帮助开发者在第四季度和未来一年获取更多广告收益。 https://www.shensh…

利用IT服务台软件提高客户满意度的4种方法

客户满意度在整个业务过程中常常会被忽视&#xff0c;但其却是业务增长的重要因素。显而易见&#xff1a;满意的客户会在曾购买过的产品上停留更长的时间&#xff0c;也更有可能交叉购买或再次购买。他们会表现出品牌忠诚度&#xff0c;通常会增加在贵公司的平均消费金额。 而满…

Linux ————VI编辑器

&#xff08;一&#xff09;VI编辑器 当提及Unix和Linux系统中的编辑工具&#xff0c;我们不能不提到VI编辑器。这款编辑器对于这些系统来说&#xff0c;犹如Windows系统中的记事本&#xff0c;是标配且不可或缺的。它不仅功能强大&#xff0c;而且其标准操作在各个Unix及Linux…

MySQL2:MySQL中一条查询SQL是如何执行的?

MySQL2&#xff1a;MySQL中一条查询SQL是如何执行的&#xff1f; MySQL中一条查询SQL是如何执行的&#xff1f;1.连接怎么查看MySQL当前有多少个连接&#xff1f;思考&#xff1a;为什么连接数是查看线程&#xff1f;客户端的连接和服务端的线程有什么关系&#xff1f;MySQL参数…

NCH Doxillion Plus forMac/win:超越转换,实现多格式文档无缝对接

在今天这个数字化时代&#xff0c;文档格式的转换已成为我们日常生活和工作中不可或缺的一部分。不同的文件格式&#xff0c;如.docx&#xff0c;.pdf&#xff0c;.pptx&#xff0c;.jpg等&#xff0c;常常让我们在处理和阅读时感到困扰。为了解决这个问题&#xff0c;NCH Soft…

Jmeter 接口测试,参数值为列表,如何参数化?

最近在我的教学过程中&#xff0c;我的一个学生问了我一个问题&#xff0c;他们公司的一个接口参数值是列表&#xff0c;列表中值的数量有多有少&#xff0c;问我在 jmeter 中如何让这个参数的值进行参数化&#xff1f; 看到这种问题&#xff0c;你的第一反应是什么&#xff1f…

【Mybatis源码】XMLConfigBuilder构建器 - 读取XML配置初始化Configuration对象

XMLConfigBuilder是Mybatis中定义的进行构建Configuration对象的类,此类用于读取XML配置文件创建并初始化Configuration对象; 上一篇中我们介绍了XMLConfigBuilder构建器加载XML配置文件以及创建Configuration对象https://blog.csdn.net/m1729339749/article/details/133983…