news 2026/4/18 9:56:20

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/4/18 0:28:05

【paperzz博士生开题报告】博士开题报告写不动了?Paperzz智能辅助+权威查重,助你突破瓶颈,导师说“这思路可以申基金”!

Paperzz-AI官网免费论文查重复率AIGC检测/开题报告/文献综述/论文初稿 https://www.paperzz.cc/proposalhttps://www.paperzz.cc/proposal 副标题&#xff1a; 博士开题不是“熬”出来的&#xff0c;是“智”出来的&#xff01;Paperzz帮你搞定50文献、五级大纲、顶刊级图表、基…

作者头像 李华
网站建设 2026/4/18 3:25:56

基于VUE的数字化文档管理系统[VUE]-计算机毕业设计源码+LW文档

摘要&#xff1a;随着信息技术的飞速发展&#xff0c;数字化文档管理系统在企业和教育等领域变得越来越重要。本文介绍了一个基于VUE框架开发的数字化文档管理系统&#xff0c;详细阐述了其需求分析、系统设计&#xff08;包括架构设计、功能模块设计等&#xff09;、具体实现过…

作者头像 李华
网站建设 2026/4/18 3:26:44

基于VUE的蔬菜营销系统[VUE]-计算机毕业设计源码+LW文档

摘要&#xff1a;随着互联网技术的发展和消费者对蔬菜品质与购买体验要求的提高&#xff0c;传统的蔬菜营销模式面临挑战。本文旨在设计并实现一个基于VUE框架的蔬菜营销系统&#xff0c;阐述系统的需求分析、技术选型、架构设计、功能模块设计以及具体实现过程。该系统实现了蔬…

作者头像 李华
网站建设 2026/4/17 22:35:03

12.8-12.13总结

一周总结 python语法 字符串 分割&#xff1a;传入分隔字符&#xff0c;返回分割后的字符串列表。分隔符不能是空字符串&#xff08;&#xff09; str str_1_2_name str_list str.split(_)# str_list:[str,1,2,name]拼接&#xff1a;用拼接字符调用&#xff0c;传入字符串或字…

作者头像 李华