GESP 25年6月2级 幂和数

【题目链接】

一本通 4124 幂和数
洛谷 B4357 幂和数


【题目考点】

  1. 循环结构(嵌套);

  2. 枚举法;

  3. 幂运算(pow函数);

  4. 标记法;


【解题逻辑】

  1. 定义变量 sum 并初始化为 0,用于统计 l~r 之间的幂和数个数;

  2. 枚举l~r之间的每一个数字i:

  • 初始化标记变量 f=0(表示默认 i 不是幂和数);
  • 嵌套枚举两个 2 的次幂(j 和 k 的范围 0~13,因 =8192,=16384 已超出规定数据范围);
  • 计算两个 2 的次幂之和 s1+s2,若等于当前数字 i,则将标记 f 设为 1 并跳出内层循环;
  1. 若数字 i 的标记 f=1(是幂和数),则 sum 加 1;

  2. 遍历完成后,输出统计结果 sum;


【题解代码】

  1. 输入两个整数 l 和 r:代表需要判断的数字范围;
cpp 复制代码
int l,r;
cin>>l>>r;
int sum=0;
  1. 遍历 l~r 之间的每个数字,判断是否为幂和数;
cpp 复制代码
for(int i=l;i<=r;i++){
    int f=0;// 标记变量:0表示不是幂和数,1表示是
    // 枚举第一个2的次幂(j从0到13,2^13=8192满足常规范围)
    for(int j=0;j<=13;j++){
        int s1=pow(2,j);// 计算2的j次幂
        // 枚举第二个2的次幂(k从0到13)
        for(int k=0;k<=13;k++){
            int s2=pow(2,k);// 计算2的k次幂
            if(s1+s2==i){// 两个2的次幂和等于i,说明是幂和数
                f=1;// 标记为是幂和数
                break;// 找到符合条件的组合,跳出内层循环
            }
        }
        // 优化:若已找到符合条件的组合,无需继续枚举j
        if(f==1) break;
    }
    if(f==1){// 是幂和数则计数+1
        sum++;
    }
}
  1. 输出统计结果;
cpp 复制代码
cout<<sum;
相关推荐
_F_y4 小时前
C++重点知识总结
java·jvm·c++
初願致夕霞5 小时前
Linux_进程
linux·c++
Thera7775 小时前
【Linux C++】彻底解决僵尸进程:waitpid(WNOHANG) 与 SA_NOCLDWAIT
linux·服务器·c++
Wei&Yan6 小时前
数据结构——顺序表(静/动态代码实现)
数据结构·c++·算法·visual studio code
wregjru6 小时前
【QT】4.QWidget控件(2)
c++
浅念-6 小时前
C++入门(2)
开发语言·c++·经验分享·笔记·学习
小羊不会打字6 小时前
CANN 生态中的跨框架兼容桥梁:`onnx-adapter` 项目实现无缝模型迁移
c++·深度学习
Max_uuc6 小时前
【C++ 硬核】打破嵌入式 STL 禁忌:利用 std::pmr 在“栈”上运行 std::vector
开发语言·jvm·c++
近津薪荼6 小时前
dfs专题4——二叉树的深搜(验证二叉搜索树)
c++·学习·算法·深度优先
艾莉丝努力练剑7 小时前
【Linux:文件】Ext系列文件系统(初阶)
大数据·linux·运维·服务器·c++·人工智能·算法