news 2026/4/18 11:01:21

GESP认证C++编程真题解析 | B3929 [GESP202312 五级] 小杨的幸运数

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
GESP认证C++编程真题解析 | B3929 [GESP202312 五级] 小杨的幸运数

​欢迎大家订阅我的专栏:算法题解:C++与Python实现!
本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战!

专栏特色
1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的代码实现与详细指导,帮助您夯实算法基础。
2.系统化学习路径:按照算法类别和难度分级,从基础到进阶,循序渐进,帮助您全面提升编程能力与算法思维。

适合人群:

  • 准备参加蓝桥杯、GESP、CSP-J、CSP-S等信息学竞赛的学生
  • 希望系统学习C++/Python编程的初学者
  • 想要提升算法与编程能力的编程爱好者

附上汇总帖:GESP认证C++编程真题解析 | 汇总


【题目来源】

洛谷:[B3929 GESP202312 五级] 小杨的幸运数 - 洛谷

【题目描述】

小杨认为,所有大于等于a aa的完全平方数都是他的超级幸运数。

小杨还认为,所有超级幸运数的倍数都是他的幸运数。自然地,小杨的所有超级幸运数也都是幸运数。

对于一个非幸运数,小杨规定,可以将它一直+ 1 +1+1,直到它变成一个幸运数。我们把这个过程叫做幸运化。例如,如果a = 4 a=4a=4,那么4 44是最小的幸运数,而1 11不是,但我们可以连续对1 113 33+ 1 +1+1操作,使其变为4 44,所以我们可以说,1 11幸运化后的结果是4 44

现在,小杨给出N NN个数,请你首先判断它们是不是幸运数;接着,对于非幸运数,请你将它们幸运化。

【输入】

第一行2 22个正整数a , N a, Na,N

接下来N NN行,每行一个正整数x xx,表示需要判断(幸运化)的数。

【输出】

输出N NN行,对于每个给定的x xx,如果它是幸运数,请输出lucky,否则请输出将其幸运化后的结果。

【输入样例】

2 4 1 4 5 9

【输出样例】

4 lucky 8 lucky

【算法标签】

《洛谷 B3929 小杨的幸运数》 #二分# #素数判断,质数,筛法# #GESP# #2023#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;constintN=1100005;// 最大范围inta,n;// a: 判断是否为完全平方数, n: 查询次数intb[N];// 存储每个数的结果intmain(){// 输入a和ncin>>a>>n;// 计算sqrt(a)的上取整intx=sqrt(a);if(x*x!=a){x++;}// 预处理:标记所有完全平方数的倍数// 从x开始,遍历所有可能的平方数for(inti=x;i*i<=1100000;i++){// 将i*i的所有倍数标记为自身for(intj=i*i;j<=1100000;j+=i*i){b[j]=j;// 标记j是某个平方数的倍数}}// 预处理:填充未标记的位置// 从后向前扫描,记录最近遇到的正数x=0;// 这里重新使用x作为临时变量for(inti=1100000;i>=0;i--){if(b[i]){x=b[i];// 更新最近遇到的标记值}else{b[i]=x;// 填充为最近的标记值}}// 调试输出,查看b数组前20个值// for (int i=1; i<=20; i++)// cout << b[i] << " ";// cout << endl;// 处理n个查询for(inti=1;i<=n;i++){intt;cin>>t;// 输入查询的数if(b[t]==t){cout<<"lucky"<<endl;// 是完全平方数的倍数}else{cout<<b[t]<<endl;// 输出最近的大于等于t的标记值}}return0;}

【运行结果】

2 4 1 4 4 lucky 5 8 9 lucky
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 8:18:16

2026软考备考刷题:软件设计师经典100题(答案解析)

1、中断向量提供的是&#xff08; &#xff09;。 A.中断源的设备地址 B.中断服务程序的入口地址 C.传递数据的起始地址 D.主程序的断点地址 答案:B 解析:本题是对中断的概念考查。 中断是这样一个过程: 在CPU执行程序的过程中&#xff0c;由于某一个外部的或CPU内部事件的发生…

作者头像 李华
网站建设 2026/4/18 8:31:22

(Open-AutoGLM应用内幕):电商数据中台智能化升级的关键一步

第一章&#xff1a;Open-AutoGLM应用内幕概述Open-AutoGLM 是一个面向自动化自然语言处理任务的开源框架&#xff0c;专注于将大语言模型&#xff08;LLM&#xff09;与动态推理流程相结合。其核心设计理念是通过可插拔的任务模块和自适应提示工程机制&#xff0c;实现对复杂业…

作者头像 李华
网站建设 2026/4/18 8:28:31

【2025最新】基于SpringBoot+Vue的+高校线上心理咨询室设计与实现pf管理系统源码+MyBatis+MySQL

摘要 随着社会快速发展&#xff0c;高校学生面临的心理健康问题日益突出&#xff0c;传统的线下心理咨询服务存在时间和空间限制&#xff0c;难以满足学生的即时需求。高校线上心理咨询室的设计与实现旨在为学生提供便捷、高效的心理支持服务&#xff0c;打破传统咨询的局限性。…

作者头像 李华
网站建设 2026/4/18 8:33:32

(Open-AutoGLM核心算法曝光)外卖平台如何实现毫秒级订单匹配?

第一章&#xff1a;Open-AutoGLM核心算法与外卖订单匹配的变革Open-AutoGLM作为新一代自适应图学习模型&#xff0c;正在重塑外卖平台中订单与骑手之间的动态匹配机制。其核心在于融合多源异构数据&#xff0c;通过实时图结构演化实现高精度、低延迟的智能调度。动态图构建与节…

作者头像 李华
网站建设 2026/4/18 8:18:02

从0到亿级订单:Open-AutoGLM在旅游平台的5个关键落地步骤,第3步最关键

第一章&#xff1a;从0到亿级订单的系统演进之路在互联网业务爆发式增长的背景下&#xff0c;一个订单系统往往需要经历从单体架构到分布式微服务的完整演进过程。初期系统可能仅由一个MySQL数据库和单一应用构成&#xff0c;但随着订单量突破百万、千万乃至亿级&#xff0c;架…

作者头像 李华