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;
相关推荐
智者知已应修善业13 分钟前
51单片机4按键控制共阳LED霓虹灯切换1整体闪烁2流水下3流水上4间隔闪烁】2023-10-27
c++·经验分享·笔记·算法·51单片机
洛水水18 分钟前
结构性设计模式详解
c++·设计模式
曦夜日长38 分钟前
C++ STL容器string(二):删除与插入、数据查找、自定义输入
java·开发语言·c++
fpcc2 小时前
跟我学C++中级篇—虚函数的优化
c++
智者知已应修善业2 小时前
【51单片机独立按键控制数码管自增自减】2023-10-5
c++·经验分享·笔记·算法·51单片机
ComputerInBook2 小时前
C++中“概念”(concept)之含义
开发语言·c++·概念·concept
程序员老舅2 小时前
Linux:谁把根目录卸载了?
linux·c++·容器·linux内核·文件系统·根目录
石山代码2 小时前
c++类型判断
开发语言·c++
雪度娃娃2 小时前
结构型设计模式——代理模式
java·c++·设计模式·系统安全·代理模式
故事和你912 小时前
洛谷-【图论2-1】树2
开发语言·数据结构·c++·算法·动态规划·图论