牛客网刷题 | BC120 争夺前五名

目前主要分为三个专栏,后续还会添加:

        专栏如下:                 C语言刷题解析       C语言系列文章       我的成长经历

感谢阅读!

初来乍到,如有错误请指出,感谢!


描述

期中考试开始了,大家都想取得好成绩,争夺前五名。从键盘输入 n 个学生成绩,输出每组排在前五高的成绩。

数据范围: 5≤𝑛≤50 5≤n≤50  ,成绩采取百分制并不会出现负数

输入描述:

两行,第一行输入一个整数,表示n个学生(>=5),第二行输入n个学生成绩(整数表示,范围0~100),用空格分隔。

输出描述:

一行,输出成绩最高的前五个,用空格分隔。


思路 :

第一行输入几个学生成绩

第二行输入学生成绩

然后进行比较 只打印出前五名成绩


代码 1 :

/*
思路 :
第一行输入几个学生成绩
第二行输入学生成绩
然后进行比较 只打印出前五名成绩
*/# include <stdio.h>
int main (){int n = 0;// 有范围//用户输入几个学生成绩scanf("%d",&n);int arr[n];int i = 0;//用户输入的成绩for(i = 0; i<n; i++){scanf("%d",&arr[i]);}//开始比较大小 使用冒泡排序int temp = 0;for(int j = 0; j<n;j++)//第j位为最大数{for(int k = 0; k<n;k++)//从第i+1位开始遍历数组{if(arr[j]>arr[k])//存在大于最大数的数{temp = arr[j];//把最大数和比较数进行交换arr[j] = arr[k];arr[k] = temp;}}}for(int a = 0; a<5;a++){printf("%d ",arr[a]);}   return 0;
}

 代码 2 :

#include<stdio.h>
int main(void)
{int n;int score[150]={0};//根据数据量定义数组scanf("%d",&n);for(int i=0;i<n;i++)//输入的同时也做好排序{int scor;scanf("%d",&scor);//先把输入的数存到scor中getchar();//吸收掉空格符int l=i-1;//定义一个下标,用来定位scor在数组score中的合适位置while(l>=0&&scor>score[l])//如果不越界并且前面的数比它小,则继续往前比较l--;if(l!=i-1)//如果发现比我小的数的下标不是i的前一个,则说明需要重新调整排序{l=l+1;//因为l已经定位到了比scor大的下标,所以需要先将其往后挪一位int j;for(j=i;j>l;j--)//开始将i-1至l位置的数都往后挪一位score[j]=score[j-1];score[j]=scor;//将scor上的数插入到l位置上}else//如果发现我前面的i-1的这个数都比我大,则直接插入到i位置即可score[i]=scor;}//以上已经实现了,在输入的同时也做好了从大到小的排序for(int i=0;i<5;i++)printf("%d ",score[i]);return 0;
}

代码 3 :

#include <stdio.h>
#include <math.h>
int main()
{int n = 0;int grade[40] = {0};scanf("%d",&n);int i = 0;int j = 0;int temp = 0;for(i=0; i<n; i++){scanf("%d ",&grade[i]);}for(i=0; i<n; i++){for (j=i; j<n; j++)if (grade[i] < grade[j]){temp = grade[i];grade[i] = grade[j];grade[j] = temp;}}for (i = 0; i < 5; i++){printf("%d ",grade[i]);}return 0;
}

  

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

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

相关文章

Springboot整合SpringCache+redis简化缓存开发

使用步骤&#xff1a; 1.引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-cache</artifactId> </dependency><dependency><groupId>org.springframework.boot</groupI…

Zookeeper高频面试题整理(入门到精通)

文章目录 1、什么是Zookeeper&#xff1f;2、ZooKeeper的基本数据结构是什么&#xff1f;3、Zookeeper的节点类型有哪些&#xff1f;4、Zookeeper的特点5、ZooKeeper如何保证数据一致性&#xff1f;6、什么是ZAB协议&#xff1f;7、Zookeeper的ACL机制是什么&#xff1f;8、Zoo…

平均召回(Average Recall,AR)概述

平均召回&#xff08;Average Recall&#xff0c;AR&#xff09;概述 在深度学习中&#xff0c;平均召回&#xff08;Average Recall, AR&#xff09;是一个衡量模型在不同阈值下的召回率的综合指标&#xff0c;特别常用于目标检测任务。召回率&#xff08;Recall&#xff09;…

js map遍历与promise一起使用出现的问题及解决方法

1.async/await 与Promise的关系 async/await是Promise的语法糖 let result await func() // > 等价于 func().then(result > {// code here })async function func () {return 1 } // > 等价与 function func () {return new Promise(resolve > resolve(1)) }2.…

学习java第九十七天

讲解一下核心容器&#xff08;spring context应用上下文) 模块 这是基本的Spring模块&#xff0c;提供Spring框架的基础功能&#xff0c;BeanFactory 是 任何以spring为基础的应用的核心。Spring 框架建立在此模块之上&#xff0c;它使Spring成为一个容器。 Bean工厂是工厂模式…

007 CentOS 7.9 apache-tomcat-9.0.89安装及配置

文章目录 一、准备工作二、安装Tomcat三、配置Tomcat四、启动Tomcat五、配置防火墙以允许远程访问六、测试远程访问 在CentOS 7.9上安装apache-tomcat-9.0.89.tar.gz并允许远程访问&#xff0c;可以按照以下步骤操作&#xff1a; 一、准备工作 确保已安装Java环境&#xff1a;…

MongoDB的基本操作介绍及使用

MongoDB是一种面向文档的NoSQL数据库&#xff0c;以其高性能、高可用性和易扩展性而受到广泛关注。以下是MongoDB的基本操作介绍及使用&#xff1a; 一、安装与配置 安装MongoDB相对简单&#xff0c;可以从MongoDB官网下载对应操作系统的安装包进行安装。在安装过程中&#x…

定个小目标之刷LeetCode热题(13)

今天来看看这道题&#xff0c;介绍两种解法 第一种动态规划&#xff0c;代码如下 class Solution {public int maxSubArray(int[] nums) {int pre 0, maxAns nums[0];for (int x : nums) {// 计算当前最大前缀和pre Math.max(pre x, x);// 更新最大前缀和maxAns Math.ma…

ansible.cfg forks参数

在Ansible的配置文件ansible.cfg中&#xff0c;forks参数是一个非常关键的设置&#xff0c;它控制了Ansible执行任务时的并发连接数&#xff0c;直接影响到Ansible执行 playbook 或 ad-hoc 命令时的速度和效率。 意义与作用 并发控制&#xff1a;当你使用Ansible来管理多台主…

【数据结构(邓俊辉)学习笔记】图04——双连通域分解

文章目录 0. 概述1 关节点与双连通域2 蛮力算法3 可行算法4 实现5 示例6 复杂度 0. 概述 学习下双连通域分解&#xff0c;这里略微有一点点难&#xff0c;这个算是DFS算法的非常非常经典的应用&#xff0c;解决的问题也非常非常有用。 1 关节点与双连通域 连通性很好理解&am…

rabbitmq单机安装及性能测试

RabbitMQ单机安装及性能测试 本文使用CentOS7.9安装RabbitMQ单机环境&#xff0c;并进行性能测试。 1. 安装RabbitMQ RabbitMQ依赖Erlang&#xff0c;版本配套关系参考官网&#xff1a;https://www.rabbitmq.com/docs/which-erlang。 本文安装RabbitMQ3.8.21,Erlang版本要求…

简单记录玩4399游戏flash插件问题

一、因谷歌浏览器默认禁止flash插件自动运行,所以玩家在使用谷歌浏览器,访问www.4399.com平台页面或者4399小游戏(flash资源)时,可能会出现加载异常的情况。今天教大家如何开启flash插件 二、下载falsh官方插件 地址:Flash Player官方下载中心-Flash中国官网 三、如果您…

ctfshow-web入门-命令执行(web30-web36)

目录 1、web30 2、web31 3、web32 4、web33 5、web34 6、web35 7、web36 命令执行&#xff0c;需要严格的过滤 1、web30 代码差不多&#xff0c;就是过滤的东西变多了&#xff1a; preg_match("/flag|system|php/i", $c) 这里不让用 system &#xff0c;我们…

掌握Excel字符串拼接

哈喽&#xff0c;大家好&#xff0c;我是木头左&#xff01; 在这个数字化时代&#xff0c;Excel已经成为了日常工作中不可或缺的工具。而字符串拼接作为Excel中的一项基本操作&#xff0c;对于提高工作效率、简化数据处理流程具有重要意义。本文将带你深入了解Excel字符串拼接…

离散数学答疑 4

知识点&#xff1a;什么是可结合&#xff1f; 举例A选项&#xff1a; 知识点&#xff1a;可交换性? 知识点&#xff1a;什么是阿贝尔群&#xff1f; 可交换->运算表中的元素关于主对角线对称 二阶子群的表达式 二阶子群作为一个群的子群&#xff0c;其本质是一个包含单位元…

【2024最新华为OD-C/D卷试题汇总】[支持在线评测] 伐木工(200分) - 三语言AC题解(Python/Java/Cpp)

🍭 大家好这里是清隆学长 ,一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解 💻 ACM银牌🥈| 多次AK大厂笔试 | 编程一对一辅导 👏 感谢大家的订阅➕ 和 喜欢💗 📎在线评测链接 伐木工(200分) 🌍 评测功能需要订阅专栏后私信联系清隆解…

【机器学习】Qwen2大模型原理、训练及推理部署实战

目录​​​​​​​ 一、引言 二、模型简介 2.1 Qwen2 模型概述 2.2 Qwen2 模型架构 三、训练与推理 3.1 Qwen2 模型训练 3.2 Qwen2 模型推理 四、总结 一、引言 刚刚写完【机器学习】Qwen1.5-14B-Chat大模型训练与推理实战 &#xff0c;阿里Qwen就推出了Qwen2&#x…

「前端+鸿蒙」鸿蒙应用开发-TS类-定义语法

在 TypeScript 中&#xff0c;类&#xff08;class&#xff09;是一种构建对象的结构&#xff0c;它允许你定义对象的属性和方法&#xff0c;并支持面向对象编程的基本特性&#xff0c;如封装、继承和多态。以下是 TypeScript 中类的定义和基本语法的快速入门指南。 TS快速入门…

MySQL之多表查询—表子查询

一、引言 上一篇博客学习了行子查询。&#xff08;看弹幕&#xff1a;同一张表用or,不同张表用union&#xff09; 下面接着学习子查询当中的最后一种——表子查询。 表子查询 1、概念 子查询返回的结果是多行多列&#xff0c;这种子查询称为表子查询。 2、常用的操作符 IN 3、…

46-2 护网溯源 - 企业在护网中如何溯源得分

一、企业部署蜜罐 蜜罐是什么? 蜜罐是一种网络安全工具,用于诱使攻击者前来攻击,以便收集关于攻击者行为、手段和意图的信息。 企业部署蜜罐技术旨在识别潜在的安全威胁,并采取相应的防御措施。蜜罐可以模拟各种服务和系统,如数据库服务器、Web服务器等,以便引诱攻击者。…