news 2026/6/23 11:57:50

OJ刷题小结(12.13~12.14)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
OJ刷题小结(12.13~12.14)

题目1:求n个实数去掉最大最小值后的平均值(快乐刷题周末B)

问题:

思路:

找到最大值最小值的下标,将0赋值给该下标对应的数组元素,再遍历数组,将所有元素相加,最后/(n-2)

代码:

#include<stdio.h> #include<stdlib.h> int main(){ int n; scanf("%d",&n); float *num=malloc(sizeof(int)*n); for(int i=0;i<n;i++){ scanf("%f",&num[i]); } float ave,min=num[0],max=num[0],sum=0; int idx_min=0,idx_max=0; for(int i=1;i<n;i++){ if(num[i]<min){ min=num[i]; idx_min=i; } if(num[i]>max){ max=num[i]; idx_max=i; } } num[idx_max]=0;num[idx_min]=0; for(int i=0;i<n;i++){ sum+=num[i]; } ave=sum/(n-2); printf("%.2f",ave); return 0; }

题目2:萝卜的冒泡排序(快乐刷题周末C)

问题:

思路:

冒泡排序都很熟悉了,但这题新出现了一个规则:如果存在相同的数,那么出现较早的那个数就排在后面。

错误想法:只改变第二个for循环中的if语句交换条件,num[j]>num[j+1]改为num[j]>=num[j+1]

错误原因:冒泡排序过程中,元素的位置不断变化,原始下标信息会丢失。当相邻元素相等时,我们无法通过索引直接判断到底哪个元素是先出现的

因此我们必须用idx[]记录每个元素的初始下标,元素交换的同时,让初始下标也跟着交换,保证元素与初始下标保持一致。交换条件改为num[j]>num[j+1]||(num[j]==num[j+1]&&idx[j]<idx[j+1])

代码:

#include<stdio.h> #include<stdlib.h> int main(){ int n; scanf("%d",&n); int num[100]; int idx[100]; for(int i=0;i<n;i++){ scanf("%d",&num[i]); idx[i]=i; } int count=0; for(int i=0;i<n-1;i++){ for(int j=0;j<n-1-i;j++){ if(num[j]>num[j+1]||(num[j]==num[j+1]&&idx[j]<idx[j+1])){ int t=num[j]; num[j]=num[j+1]; num[j+1]=t; int idx_t=idx[j]; idx[j]=idx[j+1]; idx[j+1]=idx_t; count++; } } } printf("%d\n",count); return 0; }

题目3:智将点兵(快乐刷题周末E)

问题:

思路:

数字在100以内,较小,可以从i=10开始暴力循环一个个判断i是否同时满足%3==a、%5==、%7==c,是的话则输出i,并将1赋值给变量is表示有解,跳出循环;不是的话is=0,输出No answer

代码:

#include<stdio.h> #include<stdlib.h> int main(){ int a,b,c; int is=0; scanf("%d %d %d",&a,&b,&c); for(int i=10;i<=100;i++){ if(i%3==a&&i%5==b&&i%7==c){ printf("%d",i); is=1; break; } } if(!is){ printf("No answer"); } return 0; }

题目4:密码发生器(快乐刷题周末F)

问题:

思路:

将输入字符串按位置%6 分成 6 组,外层for循环控制分组编号i(0~5)

内层for循环对每组字符的 ASCII 值求和,用num[i]储存

再用do-while语句嵌套将每个num[i]通过“各个位数相加”压缩成一位数字(数字根)

最终输出 6 位数字作为密码

代码:

#include<stdio.h> #include<stdlib.h> #include<string.h> int main(){ int n; scanf("%d",&n); while(n--){ char str[100]; scanf("%s",str); int num[6]={0}; for(int i=0;i<6;i++){ for(int j=i;j<strlen(str);j+=6){ num[i]+=str[j]; } // printf("%d ",num[i]); do{ int digit=0; while(num[i]>0){ digit+=num[i]%10; num[i]/=10; } num[i]=digit; } while(num[i]>=10); printf("%d",num[i]); } printf("\n"); } return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 18:05:20

systemd服务管理深入实践从入门到自定义服务

本文系统讲解systemd的核心概念、服务管理、自定义Unit文件编写&#xff0c;以及常见问题排查。前言 如果你还在用service xxx start或者写init.d脚本&#xff0c;是时候全面拥抱systemd了。 systemd是现代Linux的标准初始化系统&#xff0c;管理着系统启动、服务运行、日志记录…

作者头像 李华
网站建设 2026/6/23 8:04:07

基于微信小程序的网络安全知识科普平台系统【源码文末联系】

基于微信小程序的网络安全知识科普平台系统 两个角色&#xff08;管理员&#xff0c;用户&#xff09; 效果如下&#xff1a; 登录页面用户首页面科普分类页面智能问答页面管理员首页面用户管理页面科普知识页面轮播图管理页面研究背景 在数字化浪潮席卷全球的当下&#xff0c;…

作者头像 李华
网站建设 2026/6/23 21:26:45

基于VUE的实验室使用管理系统[VUE]-计算机毕业设计源码+LW文档

摘要&#xff1a;实验室作为科研与教学的重要场所&#xff0c;其高效管理至关重要。本文阐述了一个基于VUE框架开发的实验室使用管理系统&#xff0c;详细介绍了系统的需求分析、技术选型、架构设计、功能模块设计以及实现过程。该系统实现了用户管理、实验室管理、实验室管理员…

作者头像 李华
网站建设 2026/6/22 21:48:43

【单片机毕业设计】【mcugc-mcu911】基于单片机的多功能安防系统

一、基本介绍 功能&#xff1a; 1、通过火焰传感器检测是否发生明火&#xff0c;如果发生&#xff0c;通过继电器控制水泵灭火&#xff0c;并声光报警 2、通过MQ-2检测烟雾浓度&#xff0c;如果烟雾值大于设置的最大值&#xff0c;通过继电器控制风扇通风&#xff0c;并声光报警…

作者头像 李华
网站建设 2026/6/23 13:43:01

【单片机毕业设计】【mcugc-mcu916】基于单片机的智能家居安防系统

一、基本介绍 功能&#xff1a; 1、通过MQ-2检测烟雾浓度&#xff0c;如果烟雾值大于设置的最大值&#xff0c;声光报警&#xff0c;通过GSM发送“烟雾过高”短信 2、通过DS18B20检测温度值&#xff0c;如果温度值大于设置的最大值&#xff0c;声光报警 &#xff0c;通过GSM发送…

作者头像 李华